我正在寻找有用的解决方案,以将
Python可执行文件部署到Azure Service Fabric
有节点js here的文档,但我找不到任何与python相关的内容
最佳答案 小贴士:节省一些时间,并尝试先在本地运行.我的经验是,很多事情都可能出错,其中最难确定的是节点上的执行权.
建立
将Python部署到Service Fabric所需的步骤:
>确保在SF节点上安装了Python(包含您需要的软件包).
有两种方法可以做到这一点:
>
使用远程桌面使用您的端点“sf_cluster.westeurope.cloudapp.azure.com:node_port”导航到节点
其中node_port是(对我来说)3389-3393.然后通过从Python.org下载安装程序手动安装python.
>创建一个您在Guest Executable SetupEntryPoint中调用的python安装脚本,更多关于这一点.
在任何情况下,您都需要将Python放到节点上并确保将Python和Python / Scripts添加到节点路径中.
>
使用Guest Executable Service创建Service Fabric应用程序.
>将其指向您的python代码文件夹
>选择要运行的启动文件 – 将其留空
>选择CodePackage作为工作文件夹
>按确定.
您现在有一个服务结构应用程序,它将您的代码复制到您的服务结构群集但不执行任何操作. (实际上它可能会因为没有定义端点而对你大喊大叫,但接下来就是这样)
现在我们得到了一些黑客攻击.
Service Fabric不会像运行examples from Microsoft中的node.exe一样运行Python.exe.
所以你需要做的是创建一个run.cmd脚本,基本上这样做:
python.exe main.py
将其用作EntryPoint.
现在,您在ServiceManifest.xml中的EntryPoint如下所示:
...
<EntryPoint>
<ExeHost>
<Program>run.cmd</Program>
<Arguments></Arguments>
<WorkingFolder>CodePackage</WorkingFolder>
<ConsoleRedirection FileRetentionCount="5" FileMaxSizeInKb="2048"/> //use this to get logging (very helpful ;)
</ExeHost>
</EntryPoint>
</CodePackage>
如果你想让SetupEntryPoint为你安装python,你可以这样做:
<SetupEntryPoint>
<ExeHost>
<Program>Setup\setup.bat</Program>
<WorkingFolder>CodePackage</WorkingFolder>
</ExeHost>
</SetupEntryPoint>
我的setup.bat看起来像这样(路径有一些问题):
C:\Windows\System32\WindowsPowerShell\v1.0\powershell.exe -ExecutionPolicy Bypass -Command “.\Setup\pythonInstall.ps1”
我的解决方案中的代码被复制到这个结构中:
MyGuestExecutablePkg\
|
- Code\
- run.cmd
- main.py
- Setup\
- setup.bat
- ....
- Config\
- Settings.xml
- ServiceManifest.xml
ApplicationManifest.xml
我希望这可以帮助某些人,但是我会阅读Guest Executable文档以了解我错过的任何内容. 1
政策
有些东西需要在服务结构节点上获得精简权限,这就是为了让它运行.cmd,.bat,Python.exe等等你的服务.
以下编辑来自ApplicationManifest.xml
....
<ServiceManifestImport>
<ServiceManifestRef ServiceManifestName="MyGuestExecutablePkg" ServiceManifestVersion="1.0.0" />
<ConfigOverrides />
<Policies>
<RunAsPolicy CodePackageRef="Code" UserRef="SetupAdminUser" EntryPointType="Setup" />
<RunAsPolicy CodePackageRef="Code" UserRef="SetupAdminUser" EntryPointType="Main" />
</Policies>
</ServiceManifestImport>
....
第一个策略是提升SetupEntryPoint,而第二个策略是复制EntryPoint,也就是说.你的服务.
确保在ApplicationManifest.xml的底部定义Principals.
</DefaultServices>
<Principals>
<Users>
<User Name="SetupAdminUser">
<MemberOf>
<SystemGroup Name="Administrators" />
</MemberOf>
</User>
</Users>
</Principals>
</ApplicationManifest>
最后的想法
我作为Flask Api运行我的服务,因为这非常容易.所以“所有”Service Fabric会启动Flask API,然后确保它在崩溃时重新启动.
这样可以轻松地测试和验证部署的哪个部分崩溃,以及是否通过执行来启动和运行
netstat -na | find "5000"
在节点上验证api确实启动并运行.
在这之后,您当然需要在Azure门户中为服务结构集群打开负载balanser中的端口.