More Related Content Similar to anyenv + phpenv + php-build が便利すぎる件 (20) anyenv + phpenv + php-build が便利すぎる件1. anyenv + phpenv + php-build が
便利すぎる件
内山 雄司 (@y__uti)
2016-06-29 第103回PHP勉強会
2. 自己紹介
内山 雄司 (@y__uti)
◦ http://y-uti.hatenablog.jp/ (phpusers-ja)
仕事
◦ 受託開発の会社 (株式会社ピコラボ) でプログラマをしています
興味
◦ プログラミング言語処理系
◦ 機械学習
2016-06-29 第103回 PHP 勉強会 2
3. 目次
はじめに
anyenv を 使ってみよう
応用編
1. ディレクトリごとにバージョンを指定する
2. anyenv のプラグインを使う
3. PHP のビルド手順をカスタマイズする
4. ローカルリポジトリの運用
CHH/phpenv の話
2016-06-29 第103回 PHP 勉強会 3
4. phpenv とは
複数の PHP のバージョンをコマンド一発で切り替えるツール
2016-06-29 第103回 PHP 勉強会 4
$ php -v
PHP 5.4.16 (cli) (built: May 12 2016 13:45:17)
Copyright (c) 1997-2013 The PHP Group
Zend Engine v2.4.0, Copyright (c) 1998-2013 Zend Technologies
with Zend OPcache v7.0.3, Copyright (c) 1999-2014, by Zend Technologies
$ phpenv global 7.1.0alpha1
7.1.0alpha1
$ php -v
PHP 7.1.0alpha1 (cli) (built: Jun 23 2016 23:58:03) ( NTS )
Copyright (c) 1997-2016 The PHP Group
Zend Engine v3.1.0-dev, Copyright (c) 1998-2016 Zend Technologies
with Zend OPcache v7.1.0alpha1, Copyright (c) 1999-2016, by Zend Technologies
5. anyenv + phpenv + php-build
php-build とは
◦ PHP の超簡単ビルドシステム
2016-06-29 第103回 PHP 勉強会 5
$ phpenv install 7.1.0alpha1
◦ これだけでソースコードのダウンロードからインストールまで全自動
anyenv とは
◦ 各言語の *env を一元管理するツール
$ anyenv install rbenv
◦ これだけで Ruby でも同じように使える
これらの *env は Ruby (rbenv) が元祖。PHP が後発
7. anyenv のインストール
https://github.com/riywo/anyenv の説明どおり
1. リポジトリを clone する
2016-06-29 第103回 PHP 勉強会 7
$ git clone https://github.com/riywo/anyenv ~/.anyenv
2. 初期化ファイルに設定を追加する
$ echo 'export PATH="$HOME/.anyenv/bin:$PATH"' >> ~/.bash_profile
$ echo 'eval "$(anyenv init -)"' >> ~/.bash_profile
3. 初期化ファイルの設定を反映する
$ exec bash -l
8. phpenv のインストール
anyenv install コマンドを実行する
2016-06-29 第103回 PHP 勉強会 8
$ anyenv install phpenv
$ exec bash -l
◦ 以下がまとめてインストールされる
◦ madumlao/phpenv phpenv 本体
◦ php-build/php-build PHP をビルドするためのプラグイン
◦ ngyuki/phpenv-composer PHP のバージョンごとにパッケージを管理するプラグイン
◦ 詳しい人向けの情報
◦ CHH/phpenv ではなく madumlao/phpenv (phpenv/phpenv 系の後継) が入る
◦ 後半のスライドで違いを説明
9. phpenv の使い方 [1/5]
インストール済みの PHP のバージョンを一覧表示する
2016-06-29 第103回 PHP 勉強会 9
$ phpenv versions
* system (set by /home/y-uti/.anyenv/envs/phpenv/version)
◦ 最初は "system" だけ
◦ system というのは anyenv 管理外の PHP を表す
$ php -v
PHP 5.4.16 (cli) (built: May 12 2016 13:45:17)
Copyright (c) 1997-2013 The PHP Group
Zend Engine v2.4.0, Copyright (c) 1998-2013 Zend Technologies
with Zend OPcache v7.0.3, Copyright (c) 1999-2014, by Zend Technologies
◦ 環境により異なる (これは CentOS 7 での結果)
10. phpenv の使い方 [2/5]
利用可能な PHP のバージョンを一覧表示する
2016-06-29 第103回 PHP 勉強会 10
$ phpenv install -l
Available versions:
5.2.17
5.3.2
5.3.3
:
: (省略)
:
7.0.6
7.0.7
7.0snapshot
7.1.0alpha1
master
11. phpenv の使い方 [3/5]
バージョンを指定して PHP をインストールする
2016-06-29 第103回 PHP 勉強会 11
$ phpenv install 7.1.0alpha1
◦ 以下の一連の処理が全自動で実行される
1. PHP のソースコードをダウンロードして展開 ("master" を指定した場合は git clone)
2. PHP をビルドしてインストール
3. 拡張ライブラリをインストール (Xdebug など)
4. php.ini ファイルを更新 (OPcache を有効にするなど)
◦ インストールされたことの確認
$ phpenv versions
* system (set by /home/y-uti/.anyenv/envs/phpenv/version)
7.1.0alpha1
12. phpenv の使い方 [4/5]
PHP のバージョンを切り替える
2016-06-29 第103回 PHP 勉強会 12
$ phpenv global 7.1.0alpha1
7.1.0alpha1
$ phpenv versions
system
* 7.1.0alpha1 (set by /home/y-uti/.anyenv/envs/phpenv/version)
◦ 行頭の "*" は現在選択されている PHP のバージョンを表す
13. phpenv の使い方 [5/5]
あとは普通どおりに PHP を実行する
2016-06-29 第103回 PHP 勉強会 13
$ php -v
PHP 7.1.0alpha1 (cli) (built: Jun 23 2016 23:58:03) ( NTS )
Copyright (c) 1997-2016 The PHP Group
Zend Engine v3.1.0-dev, Copyright (c) 1998-2016 Zend Technologies
with Zend OPcache v7.1.0alpha1, Copyright (c) 1999-2016, by Zend Technologies
$ php -r 'echo "Hello, world!"[-1];'
!
◦ 文字列に負のオフセットを指定すると末尾から数える (PHP 7.1 より)
◦ https://wiki.php.net/rfc/negative-string-offsets を参照
14. rbenv (Ruby)
PHP と同じ
2016-06-29 第103回 PHP 勉強会 14
$ anyenv install rbenv
$ exec bash -l
$ rbenv install 2.4.0-preview1
$ rbenv global 2.4.0-preview1
$ ruby -e 'if (a, b = nil); p "True"; else p "False"; end'
-e:1: warning: found = in conditional, should be ==
"False"
◦ Multiple assignment in conditional expression (新機能らしいよ)
◦ https://github.com/ruby/ruby/blob/v2_4_0_preview1/NEWS
15. pyenv (Python)
PHP と同じ
2016-06-29 第103回 PHP 勉強会 15
$ anyenv install pyenv
$ exec bash -l
$ pyenv install 3.6.0a2
$ pyenv global 3.6.0a2
$ python -c 'name = "Fred"; print(f"He said his name is {name}")'
He said his name is Fred
◦ Formatted string literals (新機能らしいよ)
◦ https://docs.python.org/3.6/whatsnew/3.6.html
16. その他の言語
anyenv でインストールできる言語たち
2016-06-29 第103回 PHP 勉強会 16
$ ls -1 ~/.anyenv/share/anyenv-install | column -c 70
Renv goenv nenv rbenv
crenv hsenv nodenv sbtenv
denv jenv phpenv scalaenv
erlenv luaenv plenv swiftenv
exenv ndenv pyenv
18. phpenv local [1/5]
特定のディレクトリの配下だけ PHP のバージョンを変える
◦ 最初の状態を確認
2016-06-29 第103回 PHP 勉強会 18
$ phpenv version
system (set by /home/y-uti/.anyenv/envs/phpenv/version)
$ php -v | head -n 1
PHP 5.4.16 (cli) (built: May 12 2016 13:45:17)
19. phpenv local [2/5]
特定のディレクトリの配下だけ PHP のバージョンを変える
◦ ディレクトリを作成して・・・
2016-06-29 第103回 PHP 勉強会 19
$ mkdir -p ~/samples/php
$ cd ~/samples/php
◦ このディレクトリ配下で使いたい PHP のバージョンを指定する
$ phpenv local 7.1.0alpha1
7.1.0alpha1
20. phpenv local [3/5]
特定のディレクトリの配下だけ PHP のバージョンを変える
◦ 指定されたバージョンの PHP が使われる
2016-06-29 第103回 PHP 勉強会 20
$ php -v | head -n 1
PHP 7.1.0alpha1 (cli) (built: Jun 23 2016 23:58:03) ( NTS )
$ cd ..
$ php -v | head -n 1
PHP 5.4.16 (cli) (built: May 12 2016 13:45:17)
◦ サブディレクトリでも OK (phpenv local で指定されたバージョンが使われる)
◦ phpenv local を実行したディレクトリの外側には効果を及ぼさない
21. phpenv local [4/5]
PHP ファイルを置いた場合はどうなる?
◦ phpenv local を実行したディレクトリの配下にファイルを作成する
2016-06-29 第103回 PHP 勉強会 21
$ cd ~/samples/php
$ echo '<?php echo phpversion(), "¥n";' >phpversion.php
◦ ディレクトリの外側から実行する
$ cd ~
$ php samples/php/phpversion.php
7.1.0alpha1
◦ phpenv local で指定されたバージョンが使われる
23. 注意
これらは phpenv を通して PHP を実行しているときの話
Q. phpenv local を実行しておけば対応する libphp5.so が選ばれる?
A. いいえ
2016-06-29 第103回 PHP 勉強会 23
25. anyenv の更新
anyenv 本体や各言語の *env は git clone された状態
◦ 最新状態を取り込むには git pull すればよい
◦ 最新の PHP をビルドするには php-build を最新にする必要がある
ところが
◦ 一つ一つ git pull するのは結構めんどくさい
2016-06-29 第103回 PHP 勉強会 25
$ cd ~/.anyenv
$ git pull
$ cd envs/phpenv
$ git pull
$ cd plugins/php-build
$ git pull
$ cd ../phpenv-composer
$ git pull
26. anyenv-update
anyenv と配下の各 *env やプラグインを一括更新するプラグイン
◦ インストール方法
◦ https://github.com/znz/anyenv-update の説明どおり
2016-06-29 第103回 PHP 勉強会 26
$ mkdir ~/.anyenv/plugins
$ cd ~/.anyenv/plugins
$ git clone https://github.com/znz/anyenv-update.git
◦ 使い方
$ anyenv update
Updating 'anyenv'...
Updating 'anyenv/anyenv-update'...
Updating 'phpenv'...
...
27. anyenv-git
anyenv と配下の各 git リポジトリに git コマンドを一括発行
◦ インストール方法
◦ https://github.com/znz/anyenv-git の説明どおり
2016-06-29 第103回 PHP 勉強会 27
$ mkdir ~/.anyenv/plugins
$ cd ~/.anyenv/plugins
$ git clone https://github.com/znz/anyenv-git.git
◦ 使い方
$ anyenv git checkout -B mybranch
◦ 各 git リポジトリの mybranch ブランチをチェックアウト。無ければ作る
30. configure オプション変更 [2/2]
share/php-build/definitions/ ディレクトリにファイルを追加
◦ ファイルの例
2016-06-29 第103回 PHP 勉強会 30
$ cat share/php-build/definitions/master-debug
configure_option -D "--disable-debug"
configure_option "--enable-debug"
install_package_from_github master
enable_builtin_opcache
◦ master-debug という「バージョン」を独自に追加
◦ --disable-debug オプションを削除して --enable-debug オプションを追加
$ phpenv install master-debug
31. ./configure 後に処理を追加
share/php-build/before-install.d/ に bash スクリプトを作成
◦ bash スクリプトの例
2016-06-29 第103回 PHP 勉強会 31
#!/usr/bin/env bash
if type apxs &>/dev/null; then
apxs_libexecdir=$(apxs -q LIBEXECDIR)
sed -i -e ¥
"s|'¥$(INSTALL_ROOT)$apxs_libexecdir'|$PREFIX/libexec|g" ¥
$SOURCE_PATH/Makefile
fi
◦ libphp5.so ファイルの出力先を設定する
32. インストール後に処理を追加
share/php-build/after-install.d ディレクトリにスクリプトを作成
◦ bash スクリプトの例
2016-06-29 第103回 PHP 勉強会 32
#!/usr/bin/env bash
inifile="$PREFIX/etc/php.ini"
if [ -f "$inifile" ]; then
sed -i -e 's/^memory_limit =.*$/memory_limit = 1024M/' $inifile
sed -i -e 's/^;date.timezone =.*$/date.timezone = Asia¥/Tokyo/' $inifile
fi
◦ PHP のインストール後に php.ini を編集する
◦ memory_limit を 1024M に設定
◦ date.timezone を Asia/Tokyo に設定
33. 拡張モジュールの追加 [1/2]
share/php-build/extension/definition ファイルに定義を追加
2016-06-29 第103回 PHP 勉強会 33
$ cat definition
"name","url-dist","url_source","source_cwd","configure_args","extension_type","after_install"
...
"vld","http://pecl.php.net/get/vld-$version.tgz","https://github.com/derickr/vld.git",,,"extension",
...
項目 内容 記述例
name モジュール名 vld
url-dist 圧縮ファイル URL http://pecl.php.net/get/vld-$version.tgz
url_source リポジトリ URL http://github.com/derickr/vld.git
source_cwd ビルドディレクトリ
configure_args ./configure オプション
extension_type 拡張の種類 extension
after_install ビルド後のコールバック関数
36. ローカルリポジトリの運用
悩ましい問題
◦ 独自のカスタマイズによりリモートリポジトリとの差分が発生
◦ git pull したときにエラーになってしまう
私の運用の紹介(一例として)
2016-06-29 第103回 PHP 勉強会 36
$ anyenv git checkout -B local
◦ リモートリポジトリを pull するときは・・・
$ anyenv git checkout master
$ anyenv update
$ anyenv git rebase master local
◦ 節度を保ったカスタマイズなら滅多に conflict しない(経験上)
38. 最初に要点
今回説明した madumlao/phpenv とは別に CHH/phpenv がある
1. 機能は大差ない
2. 実績は CHH/phpenv (TravisCI で使われている)
3. anyenv で使うなら madumlao/phpenv が簡単
4. どちらも phpenv install コマンドは php-build/php-build を使う
ウェブなどで情報を調べるときは
◦ phpenv の情報はどちらの話なのか注意が必要
◦ php-build の情報はどちらの phpenv を使っていても共通
2016-06-29 第103回 PHP 勉強会 38
39. CHH/phpenv とは
rbenv (sstephenson/rbenv) を PHP 用に変更するパッチ
◦ https://github.com/CHH/phpenv
インストール方法
◦ https://github.com/php-build/php-build の説明どおり
2016-06-29 第103回 PHP 勉強会 39
$ curl -L http://git.io/phpenv-installer | bash
◦ phpenv とプラグイン数種 (php-build 含む) がインストールされる
ところで何故インストール方法が php-build に書かれているのか
◦ php-build は CHH/phpenv のプラグインとして使われる想定
◦ そもそも php-build/php-build は元々 CHH/php-build だった
40. CHH/phpenv の使い方
今回説明してきた phpenv (madumlao/phpenv) と同じ
2016-06-29 第103回 PHP 勉強会 40
$ phpenv help
Usage: rbenv <command> [<args>]
Some useful rbenv commands are:
commands List all available rbenv commands
local Set or show the local application-specific Ruby version
global Set or show the global Ruby version
shell Set or show the shell-specific Ruby version
install Install a PHP version using the php-build plugin
uninstall Uninstall a specific PHP version using the php-build plugin
rehash Rehash rbenv shims (run this after installing executables)
version Show the current Ruby version and its origin
versions List all Ruby versions available to rbenv
which Display the full path to an executable
whence List all Ruby versions that contain the given executable
See `rbenv help <command>' for information on a specific command.
For full documentation, see: https://github.com/rbenv/rbenv#readme
◦ あちこちに "rbenv" や "Ruby" と表示されていることに気付いた?
41. 改めて CHH/phpenv とは
rbenv (sstephenson/rbenv) を PHP 用に変更するパッチ
◦ CHH/phpenv のインストーラがやること
1. git clone sstephenson/rbenv して
2. PHP 用にソースコードを変更する
◦ したがって rbenv のリポジトリがそのまま見えている
2016-06-29 第103回 PHP 勉強会 41
$ cd ~/.phpenv
$ git remote show origin
* remote origin
Fetch URL: https://github.com/sstephenson/rbenv.git
Push URL: https://github.com/sstephenson/rbenv.git
...
◦ clone した後にソースコードを変更しているので diff も出ている
42. phpenv/phpenv
rbenv (sstephenson/rbenv) をベースとした PHP 向けの実装
◦ https://github.com/phpenv/phpenv
CHH/phpenv との主な違い
◦ rbenv に依存していない
◦ phpenv install コマンドを独自実装している
◦ php-build を使っていない
◦ php-build ほど高機能ではなかった (シェルスクリプト 1 ファイルでの実装)
開発が止まっている
◦ 最終コミットは 2013 年 11 月 (dev branch)
2016-06-29 第103回 PHP 勉強会 42
44. anyenv で使われる phpenv
~/.anyenv/share/anyenv-install/phpenv に書かれている
2016-06-29 第103回 PHP 勉強会 44
$ cat ~/.anyenv/share/anyenv-install/phpenv
install_env "https://github.com/madumlao/phpenv.git" "master"
install_plugin "php-build" "https://github.com/php-build/php-build.git" "master"
install_plugin "phpenv-composer" https://github.com/ngyuki/phpenv-composer "master"
◦ 現在は madumlao/phpenv
◦ 時期によって異なる
◦ phpenv/phpenv 0000-00-00 ~ 2014-08-17
◦ laprasdrum/phpenv 2014-08-17 ~ 2016-03-26
◦ madumlao/phpenv 2016-03-26
45. anyenv + CHH/phpenv [1/2]
私は使っていないので十分に検証できていません
anyenv の管理下で CHH/phpenv を使う
◦ phpenv を ~/.anyenv/envs/ ディレクトリ以下に置けばよい
2016-06-29 第103回 PHP 勉強会 45
$ curl -L http://git.io/phpenv-installer |¥
PHPENV_ROOT=~/.anyenv/envs/phpenv bash
46. anyenv + CHH/phpenv [2/2]
私は使っていないので十分に検証できていません
git pull できない問題の対応
◦ rbenv からの差分を別ブランチに commit する
2016-06-29 第103回 PHP 勉強会 46
$ cd ~/.anyenv/envs/phpenv
$ git checkout -b local
$ git add bin/phpenv
$ git commit -a
◦ 本発表の「応用編 4 ローカルリポジトリの運用」を参照
一応これで anyenv update できるようになるが・・・
◦ rbenv の変更に応じて phpenv を更新するわけではないので微妙
47. まとめ
anyenv + phpenv + php-build 便利!
対抗馬 (私は使っていないので詳しくありません)
◦ Homebrew
◦ direnv
2016-06-29 第103回 PHP 勉強会 47