compiler.build.productionServerArchive
MATLAB Production Server または Docker にデプロイするアーカイブを作成する
構文
説明
compiler.build.productionServerArchive( は、FunctionFiles)FunctionFiles で指定された MATLAB® 関数を使用してデプロイ可能なアーカイブを作成します。
compiler.build.productionServerArchive( は、名前と値の引数を 1 つ以上使用して追加オプションを指定してデプロイ可能なアーカイブを作成します。オプションには、アーカイブ名、JSON 関数シグネチャ、および出力ディレクトリなどがあります。FunctionFiles,Name,Value)
compiler.build.productionServerArchive( は、opts)compiler.build.ProductionServerArchiveOptions オブジェクト opts を使用してオプションを指定してデプロイ可能なアーカイブを作成します。名前と値の引数を使用して他のオプションを指定することはできません。
例
デプロイ可能なサーバー アーカイブを作成します。
MATLAB で、アーカイブとしてデプロイする MATLAB 関数を見つけます。この例では、 にあるファイル matlabroot\extern\examples\compilermagicsquare.m を使用します。
appFile = which('magicsquare.m');compiler.build.productionServerArchive コマンドを使用して Production Server アーカイブをビルドします。
compiler.build.productionServerArchive(appFile);
この構文により、現在の作業ディレクトリの mymagicproductionServerArchive という名前のフォルダー内に以下のファイルが生成されます。
includedSupportPackages.txt— アーカイブに含まれている、すべてのサポートされるファイルをリストしたテキスト ファイル。mymagic.ctf— デプロイ可能な Production Server アーカイブ ファイル。mccExcludedFiles.log— アプリケーションに含まれていないすべてのツールボックス関数のリストが含まれるログ ファイル。サポートされていない関数の詳細については、MATLAB Compiler の制限を参照してください。readme.txt— デプロイの前提条件に関する情報と、デプロイ用にパッケージ化するファイルのリストが含まれる Readme ファイル。requiredMCRProducts.txt— MATLAB Runtime がアプリケーションを実行するために必要な製品の製品 ID が含まれるテキスト ファイル。
Production Server アーカイブを作成し、名前と値の引数を使用してカスタマイズします。
この例では、 にあるファイル matlabroot\extern\examples\compileraddmatrix.m と subtractmatrix.mat を使用します。
addFile = fullfile(matlabroot,'extern','examples','compilersdk','c_cpp','matrix','addmatrix.m'); subFile = fullfile(matlabroot,'extern','examples','compilersdk','c_cpp','matrix','subtractmatrix.m');
compiler.build.productionServerArchive コマンドを使用して Production Server アーカイブをビルドします。名前と値の引数を使用してアーカイブ名を指定し、詳細な出力を有効にします。
compiler.build.productionServerArchive({addFile,subFile}, ...
'ArchiveName','MatrixArchive', ...
'Verbose','on');この構文により、現在の作業ディレクトリの MatrixArchiveproductionServerArchive という名前のフォルダー内に以下のファイルが生成されます。
includedSupportPackages.txt— アーカイブに含まれている、すべてのサポートされるファイルをリストしたテキスト ファイル。MatrixArchive.ctf— デプロイ可能な Production Server アーカイブ ファイル。mccExcludedFiles.log— アプリケーションに含まれていないすべてのツールボックス関数のリストが含まれるログ ファイル。サポートされていない関数の詳細については、MATLAB Compiler の制限を参照してください。readme.txt— デプロイの前提条件に関する情報と、デプロイ用にパッケージ化するファイルのリストが含まれる Readme ファイル。requiredMCRProducts.txt— MATLAB Runtime がアプリケーションを実行するために必要な製品の製品 ID が含まれるテキスト ファイル。
compiler.build.ProductionServerArchiveOptions オブジェクトを使用して複数の Production Server アーカイブをカスタマイズします。
この例では、 にあるファイル matlabroot\extern\examples\compilerhello.m を使用します。
functionFile = which('hello.m'); ProductionServerArchiveOptions オブジェクトを作成します。名前と値の引数を使用して共通の出力ディレクトリを指定し、データ ファイルの自動組み込みを無効にして、詳細な出力を有効にします。
opts = compiler.build.ProductionServerArchiveOptions(functionFile, ... 'OutputDir','D:\Documents\MATLAB\work\ProductionServerBatch', ... 'AutoDetectDataFiles','off', ... 'Verbose','on')
opts =
ProductionServerArchiveOptions with properties:
ArchiveName: 'hello'
FunctionFiles: {'C:\Program Files\MATLAB\R2025b\extern\examples\compiler\hello.m'}
FunctionSignatures: ''
RoutesFile: ''
AdditionalFiles: {}
AutoDetectDataFiles: off
ExternalEncryptionKey: [0×0 struct]
ObfuscateArchive: off
SecretsManifest: ''
SupportPackages: {'autodetect'}
Verbose: on
OutputDir: 'D:\Documents\MATLAB\work\ProductionServerBatch'ProductionServerArchiveOptions オブジェクトを使用して Production Server アーカイブをビルドします。
compiler.build.productionServerArchive(opts);
同じオプションをもつ関数ファイル houdini.m を使用してコンパイルするには、ビルド関数を再度実行する前に、ドット表記を使用して既存の ProductionServerArchiveOptions オブジェクトの FunctionFiles を変更します。
opts.FunctionFiles = which('houdini.m');
compiler.build.productionServerArchive(opts);FunctionFiles 引数を変更して再コンパイルすることにより、同じオプション オブジェクトを使用して複数のアーカイブをコンパイルできます。
Linux® システムで Production Server アーカイブをビルドした結果を使用して、マイクロサービスの Docker® イメージを作成します。
システムに Docker をインストールして構成します。
magicsquare.m を使用して Production Server アーカイブを作成し、ビルド結果を compiler.build.Results オブジェクトに保存します。
appFile = which('magicsquare.m');
buildResults = compiler.build.productionServerArchive(appFile);Results オブジェクトを関数 compiler.package.microserviceDockerImage への入力として渡して、Docker イメージをビルドします。
compiler.package.microserviceDockerImage(buildResults);
この関数により、現在の作業ディレクトリにある magicsquaremicroserviceDockerImage という名前のフォルダーに以下のファイルが生成されます。
applicationFilesForMATLABCompiler/magicsquare.ctf— デプロイ可能なアーカイブ ファイル。Dockerfile— Docker 実行時オプションを指定する Docker ファイル。GettingStarted.txt— デプロイ情報が含まれるテキスト ファイル。
詳細については、マイクロサービスの Docker イメージの作成を参照してください。
Production Server アーカイブを作成し、ビルド タイプ、アーカイブ ファイル、含まれるサポート パッケージ、およびビルド オプションに関する情報を compiler.build.Results オブジェクトに保存します。
ファイル magicsquare.m を使用してコンパイルします。
results = compiler.build.productionServerArchive('magicsquare.m')results =
Results with properties:
BuildType: 'productionServerArchive'
Files: {'D:\Documents\MATLAB\work\magicsquareproductionServerArchive\magicsquare.ctf'}
IncludedSupportPackages: {}
Options: [1×1 compiler.build.ProductionServerArchiveOptions]
RuntimeDependencies: [1×1 compiler.runtime.Dependencies]Files プロパティには、デプロイ可能なアーカイブ ファイル magicsquare.ctf へのパスが格納されます。
入力引数
MATLAB 関数を実装するファイル。文字ベクトル、string スカラー、string 配列、または文字ベクトルの cell 配列として指定します。ファイル パスは現在の作業ディレクトリを基準とした相対パス、または絶対パスにできます。ファイルの拡張子は .m、.p、.mlx、.mexa64 のいずれかである必要があります。
例: ["myfunc1.m","myfunc2.m"]
データ型: char | string | cell
Production Server アーカイブのビルド オプション。compiler.build.ProductionServerArchiveOptions オブジェクトとして指定します。
名前と値の引数
オプションの引数のペアを Name1=Value1,...,NameN=ValueN として指定します。ここで、Name は引数名で、Value は対応する値です。名前と値の引数は他の引数の後に指定しなければなりませんが、ペアの順序は重要ではありません。
R2021a より前では、コンマを使用して名前と値をそれぞれ区切り、Name を引用符で囲みます。
例: 'Verbose','on'
Production Server アーカイブ内に含めるファイルとフォルダーのリスト。
例: 'AdditionalFiles','MyFile.txt'
データ型: char | string | cellstr vector
デプロイ可能なアーカイブの名前。文字ベクトルまたは string スカラーとして指定します。生成されたアーカイブの既定の名前は、FunctionFiles 引数の最初のエントリです。
例: 'ArchiveName','MyMagic'
データ型: char | string
データ ファイルを自動的に含めるためのフラグ。'on' または 'off'、もしくは数値または logical の 1 (true) または 0 (false) として指定します。'on' の値は true と等価であり、'off' の値は false と等価です。したがって、このプロパティの値を logical 値として使用できます。値は、matlab.lang.OnOffSwitchState 型の on/off の logical 値として保存されます。
このプロパティを
'on'に設定した場合、特定の関数 (loadやfopenなど) の入力として指定されるデータ ファイルは自動的に Production Server アーカイブに含められます。このプロパティを
'off'に設定した場合、データ ファイルはAdditionalFilesプロパティを使用してアーカイブに追加しなければなりません。
例: 'AutoDetectDataFiles','off'
データ型: logical
R2024b 以降
外部の AES 暗号化キー ファイルおよび MEX キー ローダー ファイルへのパス。char 行ベクトルまたは string スカラーの正確に 2 つのフィールドをもつスカラー struct として指定します。フィールド名はそれぞれ EncryptionKeyFile と RuntimeKeyLoaderFile です。struct のフィールドはどちらも必須です。ファイル パスは現在の作業ディレクトリを基準とした相対パス、または絶対パスにできます。
たとえば、struct keyValueStruct を使用して暗号化キーを encrypt.key、ローダー ファイルを loader.mexw64 と指定します。
keyValueStruct.EncryptionKeyFile='encrypt.key'; keyValueStruct.RuntimeKeyLoaderFile='loader.mexw64'
暗号化キー ファイルは、サポートされている次のいずれかの形式でなければなりません。
バイナリ 256 ビットの AES キー、32 バイトのファイル サイズ
16 進数でエンコードされた AES キー、64 バイトのファイル サイズ
MEX ファイル ローダーは実行時に復号化キーを取得します。これは次の引数をもつインターフェイスでなければなりません。
prhs[0]— 入力、固定値'get'として指定される char 配列prhs[1]— 入力、CTF コンポーネント UUID として指定される char 配列plhs[0]— 出力、キーの形式に応じて 32 バイトの UINT8 数値配列または 64 バイトの 16 進数でエンコードされた char 配列
複数の CTF で同じキーを共有することは避けてください。
例: 'ExternalEncryptionKey',keyValueStruct
データ型: struct
FunctionFiles にリストされたすべての関数のシグネチャを詳述した JSON ファイルへのパス。文字ベクトルまたは string スカラーとして指定します。関数シグネチャの指定の詳細については、JSON での MATLAB 関数シグネチャ (MATLAB Production Server)を参照してください。
例: 'FunctionSignatures','D:\Documents\MATLAB\work\magicapp\signatures.json'
データ型: char | string
デプロイ可能なアーカイブを難読化するためのフラグ。'on'/1/true または 'off'/0/false として指定します。値は、matlab.lang.onoffSwitchState 型の on/off の logical 値として保存されます。
このプロパティを 'on' に設定した場合、デプロイ可能なアーカイブのフォルダー構造およびファイル名はエンド ユーザーに対して難読化され、.m、.mlapp、.p、.mat、MLX、SFX、および MEX ファイルに含まれているユーザー コードおよびデータはアーカイブ内のユーザー パッケージに配置されます。また、すべての .m ファイルがパッケージ化の前に P ファイルに変換されます。
実行時に、MATLAB コードとデータはファイル システムに抽出されるのではなく、ユーザー パッケージから直接復号化されて読み込まれます。MEX ファイルは、一時的にユーザー パッケージから抽出されてから、読み込まれます。
追加のファイル タイプをユーザー パッケージに手動で含めるには、それぞれのファイル タイプを個別の拡張子タグでファイル に追加します。matlabroot/toolbox/compiler/advanced_package_supported_files.xml
以下はサポートされて "いません"。
ver関数DLL などの外部ライブラリの呼び出し
アウトプロセスの MATLAB Runtime (MATLAB データ配列の C++ 共有ライブラリ)
アウトプロセスでの MEX ファイルの実行 (
mexhost、feval、matlab.mex.MexHost)R2023b より前: v7.3 以外の
.matファイル
このオプションを有効にすることは、-j および -s を指定して mcc を使用するのと等価です。
このプロパティを 'off' に設定した場合、デプロイ可能なアーカイブは難読化されません。これは既定の動作です。
例: 'ObfuscateArchive','on'
データ型: logical
ビルド ファイルが保存される出力ディレクトリへのパス。文字ベクトルまたは string スカラーとして指定します。このパスは現在の作業ディレクトリを基準とした相対パス、または絶対パスにできます。
ビルド フォルダーの既定の名前は、アーカイブ名に productionServerArchive を追加したものです。
例: 'OutputDir','D:\Documents\MATLAB\work\MyMagicproductionServerArchive'
R2024a 以降
カスタムの URL ルートを指定するサーバー上の JSON ファイルのパス。文字ベクトルまたは string スカラーとして指定します。
例: RoutesFile,'routes.json'
データ型: char | string
R2024b 以降
デプロイ可能なアーカイブに組み込む秘密鍵を指定する secret マニフェスト JSON ファイルへのパス。文字ベクトルまたは string スカラーとして指定します。このパスは現在の作業ディレクトリを基準とした相対パス、または絶対パスにできます。
MATLAB コードで関数 getSecret、getSecretMetadata、または isSecret を呼び出す場合、デプロイ可能なアーカイブに組み込む秘密鍵を JSON secret マニフェスト ファイルで指定しなければなりません。コードで getSecret を呼び出す場合に SecretsManifest オプションが指定されていないと、MATLAB Compiler™ は警告を発行し、 という名前の出力フォルダーにテンプレート JSON ファイルを生成します。"Embedded" フィールドで秘密鍵の名前を指定して、このファイルを修正します。<component_name>_secrets_manifest.json
関数 setSecret はデプロイ可能ではありません。デプロイ可能なアーカイブに秘密鍵を組み込むには、アーカイブをビルドする前に MATLAB で setSecret を呼び出す必要があります。
シークレットを使用したデプロイの詳細については、Handle Sensitive Information in Deployed Applicationsを参照してください。
例: 'SecretsManifest','D:\Documents\MATLAB\work\mycomponent\mycomponent_secrets_manifest.json'
データ型: char | string
含めるサポート パッケージ。次のオプションのいずれかとして指定します。
'autodetect'(既定) — 依存関係の分析プロセスにより、必要なサポート パッケージが自動的に検出され、含められます。'none'— サポート パッケージは含められません。このオプションを使用すると、ランタイム エラーの原因となる可能性があります。string スカラー、文字ベクトル、または文字ベクトルの cell 配列 — 指定されたサポート パッケージのみが含められます。インストールされている、または特定のファイルで使用されるサポート パッケージのリストを表示するには、
compiler.codetools.deployableSupportPackagesを参照してください。
例: 'SupportPackages',{'Deep Learning Toolbox Converter for TensorFlow Models','Deep Learning Toolbox Model for Places365-GoogLeNet Network'}
データ型: char | string | cell
ビルドの詳細。'on' または 'off'、もしくは数値または logical 1 (true) または 0 (false) として指定します。'on' の値は true と等価であり、'off' の値は false と等価です。したがって、このプロパティの値を logical 値として使用できます。値は、matlab.lang.OnOffSwitchState 型の on/off の logical 値として保存されます。
このプロパティを
'on'に設定した場合、MATLAB コマンド ウィンドウには、ビルド プロセス中のコンパイラ出力を示す進行状況情報が表示されます。このプロパティを
'off'に設定した場合、コマンド ウィンドウには進行状況の情報は表示されません。
例: 'Verbose','off'
データ型: logical
出力引数
ビルド結果。compiler.build.Results オブジェクトとして返されます。Results オブジェクトは以下で構成されます。
'productionServerArchive'であるビルド タイプデプロイ可能なアーカイブ ファイルへのパス
含まれているサポート パッケージのリスト
ビルド オプション。
ProductionServerArchiveOptionsオブジェクトとして指定必須およびオプションの依存関係のリスト。
Dependenciesオブジェクトとして指定します。
制限
R2024a より前のリリースでは、
compiler.build.ProductionServerArchiveでは、アーカイブ内の Web ハンドラー関数への URL リクエストのマッピングを対象とした、アーカイブ固有のルート JSON ファイルのパッケージ化はサポートされません。routes-file(MATLAB Production Server) 構成プロパティで指定された JSON ファイルでルートを定義するか、mccを使用してルート JSON ファイルをアーカイブにパッケージ化します。
バージョン履歴
R2020b で導入MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Web サイトの選択
Web サイトを選択すると、翻訳されたコンテンツにアクセスし、地域のイベントやサービスを確認できます。現在の位置情報に基づき、次のサイトの選択を推奨します:
また、以下のリストから Web サイトを選択することもできます。
最適なサイトパフォーマンスの取得方法
中国のサイト (中国語または英語) を選択することで、最適なサイトパフォーマンスが得られます。その他の国の MathWorks のサイトは、お客様の地域からのアクセスが最適化されていません。
南北アメリカ
- América Latina (Español)
- Canada (English)
- United States (English)
ヨーロッパ
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)