今回の記事ではctrlX SDKを導入する方法を紹介します。ITでずっと仕事をなさった方なら楽だと思うかもしれませんが、自分がOT側の人間でこのあたりの知識は大変不足しています。これからも色々勉強してctrlXを楽しもうと思っています。
よろしくお願いします。
ctrlX SDK?
ctrlX SDKは、ctrlX AUTOMATIONデバイス、特にLinuxベースのctrlX COREデバイス用のソフトウェアアプリケーション(APPS)を開発するためのソフトウェア開発キットです。SDKを使用するより、様々な高級言語でAPPSを開発することが可能です。
ctrlXにGithubにはDevelop-Environmentのセットアップガイド、ライブラリ、ドキュメント、REST-APIの説明などさまざまなサンプルが含まれています。つまり、私達もAPPを簡単に作成することができます!
さ、自分がもってるソフトウェアやノウハウをctrlX AUTOMATIONのエコシステムと連携しアプリケーションの可能性を開きましょう。
data:image/s3,"s3://crabby-images/25561/255613c26ab61084d55bf91d8476d79d2ac829f4" alt=""
Before..
ctrlX AUTOMATION SDKを使用してctrlX COREアプリケーションを開発するには、Ubuntu 20.04 Linuxオペレーティングシステムに特別なソフトウェアパッケージをインストールし、そしてApp Build Environmentが必要です。
こちらはSDK やApp Build Environmentに関するドキュメントです。
Prerequisites
- ctrlX WORKS >= 1.20 なおかつ function ‘App Build Environment’ が同時インストールされたPC
- インタネット接続
Reference Link
Build
ctrlX WORKSを起動し、App Build Environmentsをクリックします。
data:image/s3,"s3://crabby-images/efba0/efba09f2e72f3e10a1f9682c31c2465df773c360" alt=""
+ボタンでctrlX CORE App Build Environment を追加します。
data:image/s3,"s3://crabby-images/f2682/f26821cbfce8d29eb6f3252ebba9928226f100a7" alt=""
App Build Environmentの名前を入れて、OKで進みます。
data:image/s3,"s3://crabby-images/9ad42/9ad421747ef09bed0a1d64f4db08254be1e2b45b" alt=""
App Build Environmentが自動的にServerからImagesをDownloadし環境を構築し始めます。
data:image/s3,"s3://crabby-images/103e6/103e6e492d96be6fa1b43b300754808e28d0cc7f" alt=""
!のマークをクリックすると大体15分で終わります(自分は10分くらいで完了した)。
data:image/s3,"s3://crabby-images/152bc/152bcb0e866527e73183ef61f5baaf319296c13f" alt=""
PCにも実際Terminalが起動され、いまのインストール進捗状況を確認できます。
data:image/s3,"s3://crabby-images/d4cce/d4cce90a551659d3ba9ecfab7905dba76061a79c" alt=""
Done!
data:image/s3,"s3://crabby-images/62a8d/62a8d780b2de4a12484b9872cd61a9b29dca7e2f" alt=""
Start The build app
Stateは空でなにもマークが表示されてない状態になるはずです。
data:image/s3,"s3://crabby-images/aaf83/aaf837ec2b2c9d2ea7f3b1e78b10c20149977e88" alt=""
StartボタンでApp Build Environmentを起動します。
data:image/s3,"s3://crabby-images/5fa05/5fa05ac03a7efaa2c7793ed4b0678829902770c1" alt=""
Setup VSCODE
ctrlX AUTOMATION SDK公式ドキュメントでは統合開発環境(IDE)としてVisual Studio Codeを使用することをお勧めしてるようです。Visual Studio Codeの拡張機能を使ってctrlXアプリケーションの開発に必要なすべての機能を利用したり、SSHでLoginしたりの感じです。
こちらの記事はWindows上でWSLとVSCodeの開発環境構築がメインですが、VSCode部分は共通なので参考にしてください。簡単に言いますと、SSH 拡張機能をインストールさえインストールさえすれば今回の記事では問題ありません。
(もちろんVSCODEはMustではないので)
data:image/s3,"s3://crabby-images/d27d5/d27d58dc80c971c62ff2421e7e429f885ce22cec" alt=""
Reference Link
Connnet
SSH欄からApp Build EnvironmentのSSH Login アドレスを確認できます。注意するのはctrlX App Build EnvironmentのSSH Login Portは10022です。
data:image/s3,"s3://crabby-images/47aa6/47aa61b02ecea15d231c72b43eebc34d9dbb126c" alt=""
VSCodeからRemoteを選び>SSH のところから新しいRemote Serverを追加します。
data:image/s3,"s3://crabby-images/365c6/365c6b5c7e44bed0fb1559f8a48e01014a46f5d5" alt=""
SSH Server名を設定します。
data:image/s3,"s3://crabby-images/b4743/b47435d96372efe8776cdea009600eac66035ea2" alt=""
boschrexroth@127.0.0.1:10022を入力します。
data:image/s3,"s3://crabby-images/f979a/f979a1b9ae81538b1fb58db21c59ea4d705671df" alt=""
Passwordはboschrexrothです。
data:image/s3,"s3://crabby-images/62449/624494eeb1e0fdf9211ec34df168ff3cc429dc17" alt=""
Configを選びます。とりあえず1つ目で行きましょう。
data:image/s3,"s3://crabby-images/01dcb/01dcb043b2dd0faa9b598941509e7f4aca7a0c49" alt=""
接続すると、VSCodeの右下にSSH:127.0.0.1:10022が表示されます。
data:image/s3,"s3://crabby-images/6e668/6e6689b1a4a5e78c8475e56f21d9f7627baefaf9" alt=""
Host key verification failed
SSH Loginするときにverification failedのエラーが発生したときの対処法を紹介します。
—————– [08:13:22.971] > @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ [08:13:22.986] > @ WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! @ > @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ > IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY! > Someone could be eavesdropping on you right now (man-in-the-middle attack)! > It is also possible that a host key has just been changed. > The fingerprint for the ECDSA key sent by the remote host is > SHA256:FXXOSTwCswLlQ25/xTW2BqAhrhA0CoA/7/B5Ap+7YOo. > Please contact your system administrator. > Add correct host key in C:\\Users\\root/.ssh/known_hosts to get rid of this mess > age. > Offending ECDSA key in C:\\Users\\root/.ssh/known_hosts:1 > ECDSA host key for [127.0.0.1]:10022 has changed and you have requested strict c > hecking. > Host key verification failed. > The process tried to write to a nonexistent pipe. > [08:13:24.277] “install” terminal command done [08:13:24.278] Install terminal quit with output: Host key verification failed. [08:13:24.279] Received install output: Host key verification failed. [08:13:24.280] Failed to parse remote port from server output [08:13:24.282] Resolver error: Error: at m.Create (c:\Users\root\.vscode\extensions\ms-vscode-remote.remote-ssh-0.102.0\out\extension.js:1:584145) at t.handleInstallOutput (c:\Users\root\.vscode\extensions\ms-vscode-remote.remote-ssh-0.102.0\out\extension.js:1:582705) at t.tryInstall (c:\Users\root\.vscode\extensions\ms-vscode-remote.remote-ssh-0.102.0\out\extension.js:1:681881) at async c:\Users\root\.vscode\extensions\ms-vscode-remote.remote-ssh-0.102.0\out\extension.js:1:644110 at async t.withShowDetailsEvent (c:\Users\root\.vscode\extensions\ms-vscode-remote.remote-ssh-0.102.0\out\extension.js:1:647428) at async t.resolve (c:\Users\root\.vscode\extensions\ms-vscode-remote.remote-ssh-0.102.0\out\extension.js:1:645160) at async c:\Users\root\.vscode\extensions\ms-vscode-remote.remote-ssh-0.102.0\out\extension.js:1:720916 [08:13:24.297] —— ——————— |
Host PCの下記Pathに行ってください。
C:\Users\root\.ssh |
known_hostsをNodpadなどのEditorを開いてください。
data:image/s3,"s3://crabby-images/f0a83/f0a83ad5427b4206ec1619d2b7c275aa51bb671d" alt=""
中にLoginできないKeyを削除してください。
data:image/s3,"s3://crabby-images/8eb76/8eb7692071d0d7c0f5565c6c5e7b7c153516b39a" alt=""
Reference Link
https://note.affi-sapo-sv.com/ssh-verification-failed.php
https://www.codelab.jp/blog/?p=3240
Download the Example
次はSDKのSamplesをDownloadしApp Build Environmentを構築します。
https://github.com/boschrexroth/ctrlx-automation-sdk
ctrlXはPythonだけではなくGO/Node/cppなど様々高級言語のSampleも用意してくれます。
data:image/s3,"s3://crabby-images/36c3b/36c3b5943834858ec1f2be87bdc4d66155a19355" alt=""
Code>Downlaod ZipでExampleをDownloadしましょう。
data:image/s3,"s3://crabby-images/c9f1f/c9f1ffbb53dab9c26f873587462490e397a94712" alt=""
もう1つのVSCODEを起動し、File>Open Folderします。
data:image/s3,"s3://crabby-images/c2acb/c2acb4b7edd2165b2cb9fb0a46c42adc57d324f0" alt=""
先程GithubでDownlaodしたZipを解凍し、Open FolderでVSCodeから開きましょう。
data:image/s3,"s3://crabby-images/d19a0/d19a06f5e54a53e1adee9df9b73ca54b7b3172eb" alt=""
このように左と右でApp Build EnvironmentとLocalを同時に開いてる状態のほうが作業しやすいです。
data:image/s3,"s3://crabby-images/2bfdc/2bfdce8f7ebd9f1d423b3923740cb38c9f27695b" alt=""
Move to your APP Build
今回記事では使用するExampleはdatalayer.client.lightで、FolderをそのままApp Build EnvironmentにLoginされたVSCODE側にひっばりって行きましょう。
data:image/s3,"s3://crabby-images/2db66/2db6666084a4a07b474b6f3cb372433e0a70e988" alt=""
Yes, I trust the authorsをクリックし進みます。
data:image/s3,"s3://crabby-images/7887a/7887a0acb7415762494f93ab62de708067906423" alt=""
Copy FolderですべてのFileを移動します。
data:image/s3,"s3://crabby-images/57be7/57be786f0c9059bbdea719426bf34c017d7d80c3" alt=""
Done!
data:image/s3,"s3://crabby-images/70e2f/70e2fa4a4977bffe8f6584e1634cd182ea3b4a6f" alt=""
Necessary Script
注意するのはApp Build Environmentの/home/boschrexroth/scripts/ディレクトリには、APPを作成するには大事なスクリプトのセットが含まれています。
そして/home/boschrexroth/scripts/README.mdに、すべてのファイルがリストアップされ説明されています。
ctrlX AUTOMATION SDKの他に、ctrlx-datalayer debianパッケージ、snapcraft、クロスビルド用ライブラリがインストールされています。
ではinstall-sdk.shからctrlx-datalayer debianパッケージ、snapcraft、クロスビルド用ライブラリなどをインストールしましょう。
data:image/s3,"s3://crabby-images/ca109/ca109f9342a39f389f083e1a7cbf762c727a9ed8" alt=""
こちらのコマンドでSource Listを更新> install-sdk.shを実行できるように権限変更>最後はShell Script install-sdk.shを実行します。大体5分くらいかかります。
boschrexroth@app-builder-amd64:~$ sudo apt-get update boschrexroth@app-builder-amd64:~$ chmod +x install-sdk.sh boschrexroth@app-builder-amd64:~$ /.install-sdk.sh |
Shell Scriptが実行されたあとApp Build Environmentに様々なPackagesがインストールされました。例えばvirtualenv:
boschrexroth@app-builder-amd64:~$ pip3 install virtualenv Requirement already satisfied: virtualenv in /usr/lib/python3/dist–packages (20.0.17) |
pipとか。
boschrexroth@app-builder-amd64:~$ pip3 –version pip 20.0.2 from /usr/lib/python3/dist–packages/pip (python 3.8) |
Test with Example!
では実際ctrlX GithubからDownloadしたExampleを導入しましょう。
各Exampleにもinstall-venv.shというShell Scriptが入っています。
data:image/s3,"s3://crabby-images/dfc3d/dfc3dfd0c817b1e10c8c3cd25cad0a7402f0fd09" alt=""
中にPythonの仮想環境作成>そして仮想環境を有効>最後はrequirements.txtに記述されたLibraryをPip コマンドでInstallします。
data:image/s3,"s3://crabby-images/e35e3/e35e388dfcb2987c6da045b15bf59f01f71783a2" alt=""
Shell Scriptを実行してください。
boschrexroth@app-builder-amd64:~$ chmod +x install-venv.sh boschrexroth@app-builder-amd64:~$ ./install-venv.sh |
次はmain.pyを実行してみましょう。
data:image/s3,"s3://crabby-images/f0249/f02495a43d8a243394e18980528775e6cc2f7092" alt=""
もしエラーが発生した場合はCtrlx Virtual CoreなどのRuntimeが起動したかをCheckしてくださいね。
boschrexroth@app-builder-amd64:~$ source datalayer.client.light/venv/bin/activate (venv) boschrexroth@app-builder-amd64:~$ python datalayer.client.light/main.py System architecture: x86_64 ================================================================= sdk-py-datalayer-client – A ctrlX Data Layer Client App in Python ================================================================= ERROR Connecting tcp://boschrexroth:boschrexroth@10.0.2.2?sslport=8443 failed. |
ctrlX RuntimeのWeb ServerにアクセスしSettingsを開きます。
data:image/s3,"s3://crabby-images/c1e23/c1e238dcefe131d937be1ef3f5772bf1868037ba" alt=""
Data Layer を開きます。
data:image/s3,"s3://crabby-images/15a83/15a835f79586e17f4f5711f6f1c1dc5ee520ab54" alt=""
Data Layerのツリーが表示されました。
data:image/s3,"s3://crabby-images/53fb2/53fb2acb99fadd0a48cea0b89b03fe57af0e80de" alt=""
このExampleが読み込まれるSubscriptionの設定とCPUの使用状態ですが、Subscription設定はこのように確認できます。
data:image/s3,"s3://crabby-images/d1450/d1450cde3d54e306f8c7f607e02b61905fa4d13b" alt=""
Reference Link
PIPをインストールする手順:
https://linuxize.com/post/how-to-install-pip-on-ubuntu-20.04/
Virtualenvの使用方法:
Modify your apps
次はPython Scriptを少し修正します。ctrlX PLC Engineeringを起動し、GVLの中に整数を定義し周期で加算します。
data:image/s3,"s3://crabby-images/166cc/166cc4bb5b5e9c16dd2451b4136db655895b521b" alt=""
その変数をDataLayer_RealtimeのOutputとして追加しましょう。
data:image/s3,"s3://crabby-images/a0d00/a0d008fbfcde80c065c4e37d5ac24dbf5b6c5811" alt=""
Web Serverからひとまず確認しましょう。
data:image/s3,"s3://crabby-images/8bd91/8bd912297674d8b216923a93778c3d66bf5caa6c" alt=""
PLC RuntimeのCounter変数のアクセスPathを複製します。
data:image/s3,"s3://crabby-images/477b9/477b9cd47b7387a020dfe16b4fb8dcf1a9640788" alt=""
ExampleのPythonScriptにLine80ではSubscribeするTopicを設定しています。
先程CopyしたアクセスPathに変更しましょう。
data:image/s3,"s3://crabby-images/e11d3/e11d301eb0862c7a377f3811c9fa62487b20a75c" alt=""
Done!Counter値がDataLayer_Realtime経由で取得できました。
data:image/s3,"s3://crabby-images/00f93/00f9308f9f969c8ae92b9d93c2ae2ddd7fc9d3f0" alt=""
Build to Snap
最後はPython scriptをSnapにビルドししctrlX RuntimeにInstallしてみます。
アプリケーションを作成したFolderまでcdコマンドで移動してください。
その中に.build-snap-amd64.shのShell Scriptが入っています。
data:image/s3,"s3://crabby-images/eb7dd/eb7dd940a18712a12a6e91181f12e6e2df0ad254" alt=""
build-snap-amd64.shを実行できるように変更し、そのShell Scriptを実行しましょう。
boschrexroth@app-builder-amd64:~$ chmod +x build-snap-amd64.sh boschrexroth@app-builder-amd64:~$ /.build-snap-amd64.sh |
ヒルドされたsnapを右クリックし>DownloadでLocal PCにDownloadします。
data:image/s3,"s3://crabby-images/535b1/535b1b0861015a7671cdb6cefc6e73dcdd3ce0ed" alt=""
ctrlX VirtualcoreのWebServerにアクセスし、Install an appでAppをインストールします。
data:image/s3,"s3://crabby-images/61b25/61b2556fee77edd53da369422adc8ccd0b158da8" alt=""
Intall from fileをクリックします。
data:image/s3,"s3://crabby-images/5304b/5304b5ed8c1a376607e15227bb9c702c0ca740aa" alt=""
先程Downloadしたsnapを選び>Openします
data:image/s3,"s3://crabby-images/f103c/f103c841f13e3d60360f26d19bbb7ebe67134672" alt=""
少々お待ち下さい…
data:image/s3,"s3://crabby-images/14d0f/14d0fbd58f0a3b5cf0a95da70d474a8f36aa995c" alt=""
Installで進みます。
data:image/s3,"s3://crabby-images/dffaa/dffaad569a34bdc7fa9b6affa86264b31b364e63" alt=""
また少々お待ち下さい…
data:image/s3,"s3://crabby-images/34b0d/34b0dc9ee61eb6449ae6056fe0644c7d10344c70" alt=""
Done!
data:image/s3,"s3://crabby-images/60f79/60f79f2fd70dfbeeeb37b98b2577a134672b6b28" alt=""
Appsがインストールされました!このExampleは本来ConsoleでずっとDataLayer_Realtime経由で読み込まれた変数を表示するだけなので、実用性はありませんが、これからSDKを使用し自分のAPP を作っていきたいと思います!
data:image/s3,"s3://crabby-images/dec7c/dec7cb31a78043ea54dc1b1e548074cd0aee1724" alt=""
Stop the App Build Environment
最後はApp Build EnvironmentをStopしましょう。
data:image/s3,"s3://crabby-images/9cbc2/9cbc25d4123991047cb2c0953bd8a5af76fc27bb" alt=""
実際その環境をStopするにもPasswordが必要です。
Default Passwordはboschrexrothです。
data:image/s3,"s3://crabby-images/0cd56/0cd56f3fc5109d193f74f64f8c9a3af304e5b463" alt=""
コメント
nice