しもむブログ

技術メモ。といっても高度なことは書けないので…初心者がハマったところや、ググってもすぐには出てこないようなものを書くつもり。

在宅勤務用にダンボールデスクを購入した

  • もともと東京オリンピック時の在宅勤務用に処分が簡単なデスクがほしかった
  • 以前はこれを調べていたが、1NZD65円だとしても26,000円弱もしたので諦めた(当時はもう少し円安だった)
    • Sitting desk 200.00 NZD
    • Shipping 192.87 NZD

refold.co

  • COVID-19で在宅勤務になったが、自宅にはローテーブルしかないので床に正座しながらの仕事が1ヶ月続くのはさすがにしんどい
  • 再度調べたらちょうどよさそうなのがあった

uchidashokai.com

  • 高さ 660mmは低いと思ったが、下に雑誌とか置けばなんとでもなる
  • カスタマイズもできそうだが、何cmがいいかこだわり始めるとキリがないのでデフォルトでいく
  • webのお問い合わせフォームからコンタクトを取り、メールのやり取りで注文完了
  • 4/23に発注して、4/29にゆうパックの代金引換で到着

組み立て開始

f:id:mshimomu:20200430191052j:plain

  • 脚を組み立て中板をはめる

f:id:mshimomu:20200430191447j:plain

  • 天板をはめる

f:id:mshimomu:20200430191834j:plain

  • 組み立て完了

f:id:mshimomu:20200430191949j:plain

  • 予想通り低かったので四季報で高さ調節

f:id:mshimomu:20200430192434j:plain

  • これで在宅勤務もより捗るはず

PoCのアプリケーションログをクラウドストレージサービスで収集する

はじめに

  • PoCをやっても「1週間経って全然動いて(動かして)いませんでした」ということが何度かあった
  • どう見ても時間が無駄に流れていくだけだったのでそれをなくしたかった

やろうとしたこと

  • PoC現場をフォローするにしてもリモートでもある程度状況がわかるようにしてからにしたい
  • ログ収集するにもPoC現場の手を動かしてもらいたくない
  • いわゆるログ収集をするのはめんどくさいので楽にやりたい

やったこと

  • クラウドストレージサービスのパスにログを出せば楽にログが手に入るのでは?と考えた
  • 大人の都合でPoC専用で用意
  • クラウドストレージサービス
    • Box Sync
      • 同期タイミングはよくわからないが、必ずしもリアルタイムでわかる必要はない
      • 翌日見れれば上記の1週間経っても〜という課題は十分解決できる
      • 別にDropboxなど他のサービスでもできるはず
  • PoCアプリケーション
    • 動作で知りたいことをログを仕込んでBox Syncに出力した
    • 日単位でローテート
      • 同期の仕様はわからないが、これなら通信量も少なくできるだろうと思った

結果

  • 簡単にリモートでログが見れるようになった
    • 画像の例だとログファイルのサイズと内容から2019/7/27 16:51以降操作がされていないことがわかったので先手を打ってフォローできた
  • SIMの通信量制限にもひっかからずに動いた

OpenBlocks IoT EX1 バージョン 8(jessie)にOpenJDK8をインストールする

前提条件

  • OpenBlocks IoT EX1
  • Debian 8.11

失敗例

  • 無邪気に入れようとするがエラー
root@obsiot:~# apt-get install openjdk-8-jdk
Reading package lists... 0%Reading package lists... 100%Reading package lists... Done
Building dependency tree... 0%Building dependency tree... 0%Building dependency tree... 50%Building dependency tree... 50%Building dependency tree... 59%Building dependency tree... 90%Building dependency tree       
Reading state information... 0%Reading state information... 0%Reading state information... Done
Package openjdk-8-jdk is not available, but is referred to by another package.
This may mean that the package is missing, has been obsoleted, or
is only available from another source

E: Package 'openjdk-8-jdk' has no installation candidate
  • 探してみるがなさそう
root@obsiot:~# apt-cache search jdk
libanimal-sniffer-java - JDK/API verification tools
libanimal-sniffer-java-doc - Documentation for Animal Sniffer
jvm-7-avian-jre - lightweight virtual machine using the OpenJDK class library
libcommons-math-java - Java lightweight mathematics and statistics components
libcommons-math-java-doc - Java lightweight mathematics and statistics components - documentation
libcommons-math3-java - Java lightweight mathematics and statistics components
libcommons-math3-java-doc - Java lightweight mathematics and statistics components - documentation
fakeroot-ng - Gives a fake root environment
freemind - Java Program for creating and viewing Mindmaps
gcj-4.8-jdk - GCJ and Classpath development tools for Java(TM)
gcj-4.9-jdk - GCJ and Classpath development tools for Java(TM)
gcj-jdk - gcj and Classpath development tools for Java(TM)
libhessian-java - Java implementation of a binary protocol for web services
libhessian-java-doc - Documentation for libhessian-java
icedtea-7-plugin - web browser plugin based on OpenJDK and IcedTea to execute Java applets
libicu4j-java - Library for Unicode support and internationalization
libicu4j-4.4-java - Library for Unicode support and internationalization
libicu4j-49-java - Library for Unicode support and internationalization
japitools - Java API compatibility testing tools
default-jdk - Standard Java or Java compatible Development Kit
default-jdk-doc - Standard Java or Java compatible Development Kit (documentation)
default-jre - Standard Java or Java compatible Runtime
default-jre-headless - Standard Java or Java compatible Runtime (headless)
gcj-native-helper - Standard helper tools for creating gcj native packages
java3ds-fileloader - Java3D 3DS File Loader
libjson-simple-java - Simple, lightweight and efficient JSON toolkit for Java
jtreg - Regression Test Harness for the OpenJDK platform
libcommons-collections3-java - Apache Commons Collections - Extended Collections API for Java
libcommons-collections4-java - Apache Commons Collections - Extended Collections API for Java
libcommons-collections4-java-doc - Documentation for Commons Collections 4
libcommons-lang-java - Commons Lang - an extension of the java.lang package
libcommons-lang-java-doc - Documentation for Commons Lang - an extension of the java.lang package
libcommons-lang3-java - Extension of the java.lang package (for Java 5+)
libcommons-lang3-java-doc - Documentation for extension of the java.lang package (for Java 5+)
libcommons-launcher-java - Apache Commons Launcher - Cross platform Java application launcher
libhibernate-commons-annotations-java - Hibernate Commons Annotations
libitext1-java - Java Library to generate PDF on the Fly
libjboss-common-java - The JBoss Common Project
libjboss-marshalling-java - alternative serialization API
libjxp-java - Java template engine/script processor
libnb-javaparser-java - Parser for the Java language which is good for use in tools
libpostgresql-jdbc-java - Java database (JDBC) driver for PostgreSQL
libpostgresql-jdbc-java-doc - Java database (JDBC) driver for PostgreSQL (documentation)
libreoffice - office productivity suite (metapackage)
libslf4j-java - Simple Logging Facade for Java
mauve - free test suite for the Java Class libraries
libmaven-enforcer-plugin-java - Maven build rule execution framework
mmake - Makefile generator for Java programs
icedtea-7-jre-jamvm - Alternative JVM for OpenJDK, using JamVM
openjdk-7-dbg - Java runtime based on OpenJDK (debugging symbols)
openjdk-7-demo - Java runtime based on OpenJDK (demos and examples)
openjdk-7-doc - OpenJDK Development Kit (JDK) documentation
openjdk-7-jdk - OpenJDK Development Kit (JDK)
openjdk-7-jre - OpenJDK Java runtime, using Hotspot JIT
openjdk-7-jre-headless - OpenJDK Java runtime, using Hotspot JIT (headless)
openjdk-7-jre-lib - OpenJDK Java runtime (architecture independent libraries)
openjdk-7-jre-zero - Alternative JVM for OpenJDK, using Zero/Shark
openjdk-7-source - OpenJDK Development Kit (JDK) source files
openjdk-7-jre-dcevm - Alternative VM for OpenJDK 7 with enhanced class redefinition
libpracticalxml-java - practical XML handling routines
substance - cross-platform look & feel for Swing applications
substance-doc - cross-platform look & feel for Swing applications - documentation
testng - testing framework for Java
libtrove-java - high performance collections for java
libtrove-java-doc - high performance collections for java
libtrove3-java - high performance collections for java
libtrove3-java-doc - high performance collections for java
usepackage - utility to manage environment variables from within dotfiles
uwsgi-app-integration-plugins - plugins for integration of uWSGI and application
uwsgi-plugin-jvm-openjdk-7 - Java plugin for uWSGI (OpenJDK 7)
uwsgi-plugin-jwsgi-openjdk-7 - JWSGI plugin for uWSGI (OpenJDK 7)
libvisualvm-jni - All-in-One Java Troubleshooting Tool (JNI libraries)
visualvm - All-in-One Java Troubleshooting Tool
libwagon-java - tools to manage Maven artifacts and deployment

やったこと

  • /etc/apt/sources.listを修正
root@obsiot:~# vi /etc/apt/sources.list

deb http://ftp.jp.debian.org/debian/ jessie main
deb-src http://ftp.jp.debian.org/debian/ jessie main

# deb http://ftp.jp.debian.org/debian/ jessie-backports main
# deb-src http://ftp.jp.debian.org/debian/ jessie-backports main

#deb http://ftp.jp.debian.org/debian/ jessie-updates main  #コメントアウト
#deb-src http://ftp.jp.debian.org/debian/ jessie-updates main  #コメントアウト

deb http://security.debian.org jessie/updates main
deb-src http://security.debian.org jessie/updates main

deb http://ftp.plathome.co.jp/pub/BX1/debian/jessie ./
deb http://archive.debian.org/debian jessie-backports main  #追記
  • ファイルを2つ作成
echo "Acquire::Check-Valid-Until false;" >/etc/apt/apt.conf.d/10-nocheckvalid
echo 'Package: *\nPin: origin "archive.debian.org"\nPin-Priority: 500' >/etc/apt/preferences.d/10-archive-pin
  • 更新してインストール
apt-get update
apt-get install -t jessie-backports openjdk-8-jre-headless ca-certificates-java
apt-get install -t jessie-backports openjdk-8-jdk openjdk-8-jre
  • OpenJDK7が入っていたので切り替える
root@obsiot:~# /usr/sbin/update-java-alternatives -l
java-1.7.0-openjdk-i386 1071 /usr/lib/jvm/java-1.7.0-openjdk-i386
java-1.8.0-openjdk-i386 1069 /usr/lib/jvm/java-1.8.0-openjdk-i386
root@obsiot:~# sudo /usr/sbin/update-java-alternatives -s java-1.8.0-openjdk-i386
update-alternatives: error: no alternatives for mozilla-javaplugin.so
update-java-alternatives: plugin alternative does not exist: /usr/lib/jvm/java-8-openjdk-i386/jre/lib/i386/IcedTeaPlugin.so
  • バージョンの確認
root@obsiot:~# java -version
openjdk version "1.8.0_171"
OpenJDK Runtime Environment (build 1.8.0_171-8u171-b11-1~bpo8+1-b11)
OpenJDK Server VM (build 25.171-b11, mixed mode)
root@obsiot:~# javac -version
javac 1.8.0_171
  • いいかんじでIoT(OpenBlocks)ネタが多くなってきた

参考

OpenBlocks IoT EX1にSDカードを挿す時はマウントポイントに気をつける

  • ログを大量かつ長期間とっておきたいので念のためディスク容量を増やしておきたい
  • 開発者向けガイドを読むとMMCスロットがあり、まさにうってつけである

MMCはシステム運用に十分な信頼性を確保できない為、ファイル交換やログ保存用等にご利用ください。

  • たまたま余っていたSDカードをもらったので挿してみる
続きを読む

OpenBlocks IoT BX5にWindowsでシリアルコンソール接続する

はじめに

  • OpenBlocks IoT FamilyシリーズをIoTゲートウェイとして使っている
  • シリアルコンソール接続するのに、最初はEX1の手順でやろうとしてうまくいかなかった
  • 型番によってドライバーが違うようだ

openblocks.plathome.co.jp

やってみた

  • ドライバーはこちら

jp.silabs.com

  • 今回はWindows7なので、「VCP をダウンロード (5.3 MB) (デフォルト)」からダウンロード

f:id:mshimomu:20190117141219p:plain

  • ダウンロードしたzipファイルを解凍するとこんな感じ

f:id:mshimomu:20190117141507p:plain

  • 32bitか64bitかOSに合った方をインストールする(今回は64bit)

f:id:mshimomu:20190117143523p:plain

  • OpenBlocks BX5を接続

f:id:mshimomu:20190117142123j:plain

  • バイスマネージャーを確認すると、COM10で認識されている

f:id:mshimomu:20190117142203p:plain

  • COM10を使ってTera Termで接続
    • ボー・レート:115200
    • データ:8bit
    • パリティ:none
    • ストップ:1bit

f:id:mshimomu:20190117142346p:plain

  • 接続できたので、ユーザ名とパスワードを入れてログイン

f:id:mshimomu:20190117142702p:plain

  • ログイン成功

f:id:mshimomu:20190117143045p:plain

さいごに

  • IoTを始めて約1年半、外部公開が難しい特定メーカーのマニアックなノウハウばかり溜まっていたのだが、やっとIoTネタで記事が書けた

参考

Bitbucket ServerのウェブフックとJenkinsのGeneric Webhook Triggerでジョブを自動実行する

はじめに

先に結論

  • Parameterized Builds for Jenkinsはプロジェクト単位でJenkinsのURLを登録できるので、適切な単位でプロジェクトを分けましょう

やったこと

  • JenkinsにGeneric Webhook Trigger プラグインを入れる
    • http://JENKINS_URL/generic-webhook-trigger/invokeがトリガーになる
  • Bitbucket Serverのウェブフックを設定する
    • 上記のURLを設定

f:id:mshimomu:20181114015428p:plain

  • Jenkinsジョブのビルド・トリガを設定する

  • シェルの実行を書く

echo ---------------------------------------------------
echo "ジョブ開始"
echo "プルリクエスト: ${payload_title}"
echo "ブランチ: ${payload_branch}"
echo ---------------------------------------------------
echo 


git fetch origin
BRANCH=`echo $payload_branch |sed "s/refs\/heads\///"`
echo ---------------------------------------------------
echo "branch is $BRANCH"
echo ---------------------------------------------------
git reset --hard origin/${BRANCH}

chmod +x gradlew
  • できた

f:id:mshimomu:20181114214400p:plain

f:id:mshimomu:20181114214428p:plain

その他

  • 今回はプルリクエストだけをトリガーにしたが、Repository eventsとPull request eventsの両方をトリガーにしたい場合は、eventKeyを条件にしないといけなさそう