MySQL Connector/J 6.0 の Service Provider について
下記 記事は Connector/J 5.1 についての記事。
6.0 の場合は
$ curl -L -O https://dev.mysql.com/get/Downloads/Connector-J/mysql-connector-java-6.0.3.tar.gz $ tar xvf mysql-connector-java-6.0.3.tar.gz $ cd mysql-connector-java-6.0.3
build.xml を確認してみると下記のようになってます。
592 <!-- JDBC 4+ support of service provider mechanism. --> 593 <mkdir dir="${com.mysql.cj.build.dir.driver}/META-INF/services/" /> 594 <echo file="${com.mysql.cj.build.dir.driver}/META-INF/services/java.sql.Driver" 595 message="com.mysql.cj.jdbc.Driver" />
じゃあどのドライバを使うかというのはどこで決めてるかというと ConnectionString クラスらしい。
src/main/java/com/mysql/cj/core/ConnectionString.java 55 SINGLE_CONNECTION("jdbc:mysql://") { 58 LOADBALANCING_CONNECTION("jdbc:mysql:loadbalance://") { 70 FAILOVER_CONNECTION("jdbc:mysql://") { 82 REPLICATION_CONNECTION("jdbc:mysql:replication://") { 144 FABRIC_CONNECTION("jdbc:mysql:fabric://") { 155 X_SESSION("mysql:x://") {
ちなみに 5.1 では下記のように場所がばらけているうえにわりと力技っぽく解決してるので 6.0 でだいぶ綺麗に書きなおされているらしいということがわかる。
src/com/mysql/jdbc/NonRegisteringDriver.java 63 private static final String REPLICATION_URL_PREFIX = "jdbc:mysql:replication://"; 65 private static final String URL_PREFIX = "jdbc:mysql://"; 67 private static final String MXJ_URL_PREFIX = "jdbc:mysql:mxj://"; 69 public static final String LOADBALANCE_URL_PREFIX = "jdbc:mysql:loadbalance://";
src/com/mysql/fabric/jdbc/FabricMySQLDriver.java 97 if (!url.startsWith("jdbc:mysql:fabric://")) {
DragonFlyBSD + letsencrypt インストールログ
環境
- DragonFly v4.4.3-RELEASE
ログ
letsencrypt 日本語ドキュメント certbot ドキュメント
ものによっては certbot-auto とか letsencrypt-auto とかよくわからんのでまずは検索。
$ sudo pkg search letsencrypt letsencrypt.sh-0.2.0 Pure BASH/ZSH Lets Encrypt client
https://letsencrypt.org/docs/client-options/
中身から察するにおそらくこれらしい https://github.com/lukas2511/letsencrypt.sh
$ cd /usr/local/etc/letsencrypt.sh/
とりあえず下記のものがサンプルとしてあるので .sample を消したものを設置
config.sh domains.txt hook.sh
今回の場合はすでに nginx + php-fpm で動いてるドメインに対して 証明書が欲しいので既存の server ディレクティブに letsencrypt.sh が作るファイルが読めるような設定を追加します。 nginx についてそんなに詳しくないので、今回は .well-known/acme-challenge 以下に来るアクセスをそのまま letsencrypt.sh が生成するディレクトリのパスにしてしまう設定にします。
# for letsencrypt location ^~ /.well-known/acme-challenge/ { default_type "text/plain"; root /usr/local/etc/letsencrypt.sh/.acme-challenges/; }
/usr/local/etc/letsencrpyt.sh/config.sh
#WELLKNOWN="${BASEDIR}/.acme-challenges" WELLKNOWN="${BASEDIR}/.acme-challenges/.well-known/acme-challenge"
一応 nginx を再起動などしたあと、下記コマンドを実行して取得する。
# /usr/local/bin/letsencrypt.sh --cron
取得した後は下記のように設定すると良いと思います。最低限の設定しかいれてないのでもっと安全にするにはググッてください。
listen 443 ssl; ssl_certificate /usr/local/etc/letsencrypt.sh/certs/example.com/fullchain.pem; ssl_certificate_key /usr/local/etc/letsencrypt.sh/certs/example.com/privkey.pem;
ここまででとりあえず https でアクセスできるようになると思います。
証明書の更新についてですが、インストールしたときに下記のように表示が出ますが、この通りに /etc/periodic.conf に設定を追加すると勝手に更新されるようです。まだ動作確認まではしてません。
To use this script you should copy the examples in /usr/local/etc/letsencrypt.sh/ and at least add a domain and a contact mail address. You should also copy the openssl.cnf.sample file in /usr/local/openssl so you won't get warnings about it missing. In order to run the script regularly to update the certificates add this line to /etc/periodic.conf weekly_letsencrypt_enable="YES" Additionally the following parameters can be added to /etc/periodic.conf To run the certification renenewal as a different user weekly_letsencrypt_user="_letsencrypt" To run a script after the renewal (as root) weekly_letsencrypt_deployscript="/usr/local/etc/letsencrypt.sh/deploy.sh"
DragonFlyBSD + owncloud インストールログ
(途中)
環境
- DragonFly v4.4.3-RELEASE
- nginx 1.10.0
- PHP 7.0.6
ログ
以前に owncloud 8.2 で運用していたものを一旦動かすのと、 php7 を使いたいため pkg にあるものではなく src からインストールする。構成は nginx + php-fpm。そして news アプリを動かしたい。
https://owncloud.org/changelog/#latest8.2
とりあえず設置位置は /var/local/www 以下に置く。
# cd /usr/local/www # curl -OJL https://download.owncloud.org/community/owncloud-8.2.5.tar.bz2 # tar xvf owncloud-8.2.5.tar.bz2
下記 URL を参考に nginx 設定をする。 https://doc.owncloud.org/server/8.0/admin_manual/installation/nginx_configuration.html
pkg から インストールしたままの nginx だとそこに nginx.conf に設定を書くしか無いのでほかの linux ディストリなどで入るように conf.d を作って include する構成にする。
(後で書く)
実際に動かすと幾つか undefined error が出るので下記で入れる。
# pkg install php70-hash php70-json php70-pdo php70-pdo_mysql php70-session php70-zip php70-dom php70-xml php70-ctype php70-gd php70-zlib php70-curl php70-xmlwriter php70-simplexml
このままだと owncloud が生成する data ディレクトリなどに書き込み権限がないので書き込み権限をなんとかする。
(後で書く)
News アプリを動かす場合。
# pkg isntall php70-iconv
あと直接エラーは出てないけど下記のものが必要かもしれない。news-updater のほうで動かした時にエラーになりました。
# pkg install php70-mbstring php70-pcntl
後始末
# rm /usr/local/www/owncloud-8.2.5.tar.bz2
ついでに owncloud 8 -> 9 の際に必要なパッケージは下記の通り。
# pkg install php70-filter
そして全部終わって cron.php を動かそうとした時には下記パッケージが必要でした。
# pkg install php70-xmlreader php70-posix php70-xmlwriter
DragonFlyBSD + php7 インストールログ
目的としては php-fpm を使いたい。
環境
DragonFly v4.4.3-RELEASE
ログ
適当に検索すると下記のものが出てくる。とりあえず php7 を使うので php70 を入れる。( fpm で検索しても出てこなかった)
php55-5.5.35 PHP Scripting Language php56-5.6.21 PHP Scripting Language php70-7.0.6_1 PHP Scripting Language
$ sudo pkg install php70 Updating Avalon repository catalogue... Avalon repository is up-to-date. All repositories are up-to-date. The following 1 package(s) will be affected (of 0 checked): New packages to be INSTALLED: php70: 7.0.6_1 The process will require 17 MiB more space. 2 MiB to be downloaded. Proceed with this action? [y/N]: y php70-7.0.6_1.txz : 100% 2 MiB 350.8kB/s 00:06 Checking integrity... done (0 conflicting) [1/1] Installing php70-7.0.6_1... [1/1] Extracting php70-7.0.6_1: 100%
php-fpm が入っていることを確認
$ php-fpm -v PHP 7.0.6 (fpm-fcgi) (built: May 27 2016 16:49:24) Copyright (c) 1997-2016 The PHP Group Zend Engine v3.0.0, Copyright (c) 1998-2016 Zend Technologies
sudo php-fpm すれば動くけど rc.conf には書けるんだろうか
適当に rc.conf に書いたら動いた
$ sudo sh -c 'echo "php_fpm_enable=\"YES\"" >> /etc/rc.conf'
unix socket を使う場合、デフォルトで入っている設定が /usr/local/etc/php-fpm.d/www.conf
にあるので下記のように変更する。とりあえず /var/run 以下に socket を設置。 owner や group も nginx と同じユーザでないと permission denied になる。
listen = /var/run/php-fpm.sock ... listen.owner = www listen.group = www listen.mode = 0660
DragonFlyBSD + nginx インストールログ
単純に pkg で nginx インストールするだけ.
環境
DragonFly v4.4.3-RELEASE
ログ
事前に sudo を入れてあります。
$ sudo pkg install nginx
現時点ではバージョンは 1.10.0 らしい。
$ nginx -v nginx version: nginx/1.10.0
OS 起動時に nginx が起動するようにする。
$ sudo sh -c 'echo "nginx_enable=\"YES\"" >> /etc/rc.conf'
nginx 起動
$ sudo service nginx start Performing sanity check on nginx configuration: nginx: the configuration file /usr/local/etc/nginx/nginx.conf syntax is ok nginx: configuration file /usr/local/etc/nginx/nginx.conf test is successful Starting nginx.
設定ファイルは 上記のとおり /usr/local/etc/nginx/nginx.conf にある。
一つのリポジトリに複数サーバの etckeeper で push する
一つのリポジトリに複数サーバの etckeeper で push したい。
etckeeper は一つのサーバから複数のリモートリポジトリに push できるような設定はあるが逆に 複数のサーバから 一つのリモートリポジトリに push できるようにする設定はなさそう。
etckeeper は master しか使わないみたいなのでそのまま使うと push できるのは master のみ。なので下記のように push のフックで push するブランチ先を指定するようにすると一旦はよさそう。
diff --git a/etckeeper/commit.d/99push b/etckeeper/commit.d/99push index b5418f7..a8d20d9 100755 --- a/etckeeper/commit.d/99push +++ b/etckeeper/commit.d/99push @@ -2,7 +2,7 @@ if [ -n "$PUSH_REMOTE" ]; then if [ "$VCS" = git ] && [ -d .git ]; then for REMOTE in $PUSH_REMOTE; do - git push "$REMOTE" master || true + git push "$REMOTE" master:mybranch || true done elif [ "$VCS" = hg ] && [ -d .hg ]; then for REMOTE in $PUSH_REMOTE; do
HttpComponents で JSON レスポンスをオブジェクトに変換して取得する
チュートリアルに書いてあるとおり ResponseHandler を使うと HttpClient#execute() の返り値を特定のクラスにして返すようにできる。これを jackson を使って返すようにしてみた。
http://hc.apache.org/httpcomponents-client-4.5.x/tutorial/html/fundamentals.html#d5e199
ResponseHandler (Apache HttpClient 4.5.2 API)
public class JacksonResponseHandler<T> implements ResponseHandler<T> { private static final ObjectMapper mapper = new ObjectMapper(); private TypeReference<T> typeRef; @Override public T handleResponse(HttpResponse response) throws IOException { HttpEntity entity = response.getEntity(); if (entity == null) { throw new ClientProtocolException("Response contains no content"); } if (!entity.getContentType().getValue().startsWith("application/json")) { throw new ClientProtocolException("Response is not json"); } InputStream content = entity.getContent(); if (content == null) { throw new ClientProtocolException("Response contains no content"); } try { return mapper.readValue(content, typeRef); } catch (IOException e) { throw new ClientProtocolException("cannot parse as response", e); } } }