開発環境



2012年 9月 24

perlbrewのインストール

Perlbrew
perlbrew

本家の手順でインストール&初期設定

$ curl -kL http://install.perlbrew.pl | bash
$ ~/perl5/perlbrew/bin/perlbrew init
$ echo 'source ~/perl5/perlbrew/etc/bashrc' >> ~/.bashrc
$ source ~/.bashrc
エラーの対処

CentOS5.7で試していたところエラーが出た。
Use of uninitialized value in split at… は一時的なもの(perlをインストールすれば治る??)らしい。
manpath: invalid option — q は ~/perl5/perlbrew/etc/bashrc を修正することで治る。

Use of uninitialized value in split at /loader/0x84417f8/local/lib.pm line 8.
manpath: invalid option -- q
manpath, version 1.6d

usage: manpath [-adfhktwW] [section] [-M path] [-P pager] [-S list]
	[-m system] [-p string] name ...

参考:

cpanmのインストール

perlbrewを使ってcpanmを入れておけばバージョンごとにcpanmを入れなおさなくて済むので楽らしい。

$ perlbrew install-cpanm

参考:[まとめ] さくらのVPSで一気に perl の環境を整える – ワタブログ

その他

インストール先はGMOクラウドのVMだったのですが、perlをインストールするのにエラーで失敗していました。
結局DNSが名前解決できなかったのが原因だったのですが、CPAN等一部のドメインだけが名前解決できなかったので気がつくまで時間が掛かってしまいました…。
GoogleのpublicDNSサーバ(8.8.8.8)を使うことでとりあえず解決しましたが、デフォルトで設定してあるDNSサーバは一体…。


Filed under: perl,インストールメモ,開発環境

Trackback Uri






2012年 5月 30

MAMP

ApacheもMySQLも常時起動しておくのは微妙だし、でも使う時にはサクッと使いたい。そんな時にMAMPがあればローカルのApacheとMySQLを自動で起動してくれるから便利。phpMyAdminもついてるしね。
インストールメモはこっち

で、MAMPデフォルトのMySQLではなく、先日インストールしたmroonga対応のMySQLをMANPで使えるようにする。

MySQLのrootユーザーのパスワードを設定

MAMPのMySQLはデフォルトで ユーザーroot パスワードrootで設定されているので同じように設定する(方が簡単?)ローカルのMySQLだからroot:rootでもおkでしょう。

MacBook:~ clicktx$ sudo /opt/local/share/mysql55/support-files/mysql.server start
Password:
Starting MySQL
.. SUCCESS! 
MacBook:~ clicktx$ /opt/local/lib/mysql55/bin/mysql -uroot
mysql> SET PASSWORD FOR root@localhost=PASSWORD('root');
Query OK, 0 rows affected (0.00 sec)
mysql> quit
Bye

で、MySQLサーバを停止。

MacBook:~ clicktx$ sudo /opt/local/share/mysql55/support-files/mysql.server stop
Shutting down MySQL
. SUCCESS! 

MAMPの起動スクリプトを編集

/Applications/MAMP/bin/ の中にあるMySQL起動スクリプトや停止スクリプト等を編集する。編集するファイルは

  • checkMysql.sh
  • repairMysql.sh
  • startMysql.sh
  • stop.sh

の4つ。オリジナルはコピーしておきましょう。中身はこんな感じ。

checkMysql.sh

# /bin/sh
#/Applications/MAMP/Library/bin/mysqlcheck --all-databases --check --check-upgrade -u root -proot --socket=/Applications/MAMP/tmp/mysql/mysql.sock
/opt/local/lib/mysql55/bin/mysqlcheck --all-databases --check --check-upgrade -u root -proot --socket=/Applications/MAMP/tmp/mysql/mysql.sock

repairMysql.sh

# /bin/sh
#/Applications/MAMP/Library/bin/mysqlcheck --all-databases --repair -u root -proot --socket=/Applications/MAMP/tmp/mysql/mysql.sock
/opt/local/lib/mysql55/bin/mysqlcheck --all-databases --repair -u root --socket=/Applications/MAMP/tmp/mysql/mysql.sock

startMysql.sh

# /bin/sh
#/Applications/MAMP/Library/bin/mysqld_safe --port=3306 --socket=/Applications/MAMP/tmp/mysql/mysql.sock --lower_case_table_names=0 --pid-file=/Applications/MAMP/tmp/mysql/mysql.pid --log-error=/Applications/MAMP/logs/mysql_error_log &
/opt/local/lib/mysql55/bin/mysqld_safe --port=3306 --socket=/Applications/MAMP/tmp/mysql/mysql.sock --lower_case_table_names=0 --pid-file=/Applications/MAMP/tmp/mysql/mysql.pid --log-error=/Applications/MAMP/logs/mysql_error_log &

stop.sh

# /bin/sh
#/Applications/MAMP/Library/bin/mysqladmin -u root -proot --socket=/Applications/MAMP/tmp/mysql/mysql.sock shutdown
/opt/local/lib/mysql55/bin/mysqladmin -u root --socket=/Applications/MAMP/tmp/mysql/mysql.sock shutdown

動作確認

普通にアイコンダブルクリックでMAMPを起動するだけ。
ブラウザが立ち上がって下のような画面が出ればおk。

MAMP起動画面

phpMyAdminタブからエンジンを見てみるとストレージエンジンにmroongaが見える。

mroongaストレージエンジンを確認

これでテーブル作ったりデータ入れたりがGUIで出来るね!


Filed under: MySQL,phpmyadmin,メモ,開発環境

Trackback Uri






2012年 5月 9

※一番下の追記にありますが、Homebrewでインストールできるようになってます(2012/5/29リリース)

MySQL5.5のインストール

MANPでMySQL使えるんだけど、mroongaを(ローカルテストでも)使いたいので別にMySQLをインストールする。

ただしMySQLのバージョンは5.5をインストールしたいのでコマンドはこんな感じに。
mysql5 +server としてしまうとMySQL5.1.6が入ります。

MacBook:~ clicktx$ sudo port install mysql55 +server
Password:
--->  Deactivating mysql55 @5.5.23_0
--->  Cleaning mysql55
--->  Uninstalling mysql55 @5.5.23_0
--->  Cleaning mysql55
MacBook:~ clicktx$ sudo port install mysql55 +server
--->  Computing dependencies for mysql55
--->  Fetching archive for mysql55
--->  Attempting to fetch mysql55-5.5.23_0.darwin_10.x86_64.tbz2 from http://packages.macports.org/mysql55
--->  Fetching mysql55
--->  Verifying checksum(s) for mysql55
--->  Extracting mysql55
--->  Applying patches to mysql55
--->  Configuring mysql55
--->  Building mysql55
--->  Staging mysql55 into destroot
--->  Installing mysql55 @5.5.23_0
The mysql55 client has been installed.
To install the mysql55 server, install the mysql55-server port.
--->  Activating mysql55 @5.5.23_0
--->  Cleaning mysql55

MySQLの初期化

  • mac OSXの場合はmysqlユーザーは作成済みなので改めて作成する必要はない。
  • 実際は_mysql?mysqlでユーザー指定しても_mysqlで処理される。
MacBook:~ clicktx$ sudo -u mysql /opt/local/lib/mysql55/scripts/mysql_install_db
Password:
Installing MySQL system tables...
OK
Filling help tables...
OK

To start mysqld at boot time you have to copy
support-files/mysql.server to the right place for your system

PLEASE REMEMBER TO SET A PASSWORD FOR THE MySQL root USER !
To do so, start the server, then issue the following commands:

/opt/local/lib/mysql55/bin/mysqladmin -u root password 'new-password'
/opt/local/lib/mysql55/bin/mysqladmin -u root -h MacBook.local password 'new-password'

Alternatively you can run:
/opt/local/lib/mysql55/bin/mysql_secure_installation

which will also give you the option of removing the test
databases and anonymous user created by default.  This is
strongly recommended for production servers.

See the manual for more instructions.

You can start the MySQL daemon with:
cd /opt/local ; /opt/local/lib/mysql55/bin/mysqld_safe &

You can test the MySQL daemon with mysql-test-run.pl
cd /opt/local/mysql-test ; perl mysql-test-run.pl

Please report any problems with the /opt/local/lib/mysql55/bin/mysqlbug script!

MySQLを起動する

MacBook:~ clicktx$ sudo /opt/local/share/mysql55/support-files/mysql.server start
Starting MySQL
... ERROR! The server quit without updating PID file (/opt/local/var/db/mysql55/MacBook.local.pid).

そのまま起動すると上記のようにエラーとなってしまう(自分の環境だけ?)

デフォルトでは /opt/local/var/run/mysql55 以下にソケットファイルを作成するらしく、フォルダが無いので作成する。アクセス権も777を与える。

MacBook:~ clicktx$ sudo mkdir -m 777 -p /opt/local/var/run/mysql55

改めてMySQLを起動。

MacBook:~ clicktx$ sudo /opt/local/share/mysql55/support-files/mysql.server start
Starting MySQL
.. SUCCESS! 

成功

参考:

  • Mac OS X に MacPorts で MySQL をインストールする – make world
  • MacPortsを使ってMySQL 5をインストールする – めも帖
  • mroongaのインストール

    2. インストールガイド — mroonga v2.02 documentation

    2.11.3. 前提条件
    MySQLおよびgroongaが既にインストールされている必要があります。
    またmroongaをビルドするためにはMySQLのソースコードも必要です。

    先日groongaはインストール済み。

    先程MacPortsでインストールしたMySQLのでソースは
    /opt/local/var/macports/distfiles/mysql55/mysql-5.5.23.tar.gz
    かな?

    作業スペースを~/src にする。
    まずは作業スペースとなるsrcフォルダを作成。

    MacBook:~ clicktx$ mkdir ~/src

    MySQLのソースファイルを ~/src にコピーして解凍する

    MacBook:~ clicktx$ cp /opt/local/var/macports/distfiles/mysql55/mysql-5.5.23.tar.gz ~/src/mysql-5.5.23.tar.gz
    MacBook:~ clicktx$ cd src/
    MacBook:~ clicktx$ tar xzvf mysql-5.5.23.tar.gz

    mroongaをダウンロード&解凍

    MacBook:src clicktx$ wget http://cloud.github.com/downloads/mroonga/mroonga/mroonga-2.02.tar.gz
    MacBook:src clicktx$ tar xzvf mroonga-2.02.tar.gz 
    

    mroongaをビルドする

    MacBook:src clicktx$ cd mroonga-2.02
    MacBook:mroonga-2.02 clicktx$ ./configure PKG_CONFIG_PATH=/opt/local/lib/pkgconfig --with-mysql-source=$HOME/src/mysql-5.5.23 --with-mysql-config=/opt/local/lib/mysql55/bin/mysql_config
    MacBook:mroonga-2.02 clicktx$ make

    makeでコケる…
    googleで漁っているとこんなの発見。
    installing mroonga on Mac OS X Lion — Gist
    早速試してみる。

    MacBook:~ clicktx$ cd ~/src/mysql-5.5.23/include
    MacBook:include clicktx$ ln -s probes_mysql_nodtrace.h probes_mysql_dtrace.h
    MacBook:include clicktx$ cd ~/src/mroonga-2.02
    MacBook:mroonga-2.02 clicktx$ aclocal -I /opt/local/share/aclocal
    MacBook:mroonga-2.02 clicktx$ automake -a
    MacBook:mroonga-2.02 clicktx$ autoconf
    MacBook:mroonga-2.02 clicktx$ autoheader
    MacBook:mroonga-2.02 clicktx$ automake -a
    MacBook:mroonga-2.02 clicktx$ ./configure PKG_CONFIG_PATH=/opt/local/lib/pkgconfig --with-mysql-source=$HOME/src/mysql-5.5.23 --with-mysql-config=/opt/local/lib/mysql55/bin/mysql_config --with-mecab
    MacBook:mroonga-2.02 clicktx$ make

    コケる…

    mroongaをMac OSXでビルドするためのアドホックなパッチを書いてみた « いわぶろ(ろてん)
    ココらへんに解決策?もう神頼み。
    https://gist.github.com/1015079 を参考に、~/src/mroonga-2.02/ha_mroonga.cpp っていうファイルの560行目付近に

    static_cast(static_cast(pthread_self())),

    っていう箇所があるから、

    static_cast(static_cast((unsigned long int)pthread_self())),

    に修正。
    pthread_self で検索すると修正箇所がすぐ分かる。

    修正した後にmakeしたら見事成功。

    MacBook:mroonga-2.02 clicktx$ sudo make install
    .....
    libtool: install: ranlib /opt/local/lib/mysql55/plugin/ha_groonga.a

    インストールできたぽい。

    公式ガイドに

    その後、mysqldを起動し、mysqlクライアントで接続して”INSTALL PLUGIN”コマンドでインストールします。

    とあるので、MySQL起動してインストール&確認。

    MacBook:~ clicktx$ sudo /opt/local/share/mysql55/support-files/mysql.server start
    MacBook:~ clicktx$ /opt/local/lib/mysql55/bin/mysql -u root
    mysql> INSTALL PLUGIN mroonga SONAME 'ha_mroonga.so';
    Query OK, 0 rows affected (0.48 sec)
    
    mysql> SHOW ENGINES;
    +--------------------+---------+------------------------------------------------------------+--------------+------+------------+
    | Engine             | Support | Comment                                                    | Transactions | XA   | Savepoints |
    +--------------------+---------+------------------------------------------------------------+--------------+------+------------+
    | CSV                | YES     | CSV storage engine                                         | NO           | NO   | NO         |
    | PERFORMANCE_SCHEMA | YES     | Performance Schema                                         | NO           | NO   | NO         |
    | InnoDB             | DEFAULT | Supports transactions, row-level locking, and foreign keys | YES          | YES  | YES        |
    | MyISAM             | YES     | MyISAM storage engine                                      | NO           | NO   | NO         |
    | MRG_MYISAM         | YES     | Collection of identical MyISAM tables                      | NO           | NO   | NO         |
    | MEMORY             | YES     | Hash based, stored in memory, useful for temporary tables  | NO           | NO   | NO         |
    | mroonga            | YES     | CJK-ready fulltext search, column store                    | NO           | NO   | NO         |
    +--------------------+---------+------------------------------------------------------------+--------------+------+------------+
    7 rows in set (0.00 sec)

    なんとか入ったみたい。
    苦労した…。

    なお参考ブログに

    なお,MySQLへの組み込み後の動作については,何も確認を行っていないのであしからず,です.(影響があるとしても,ログ出力部分だけ?)

    とあるように、とりあえずmake出来て、インストールまでこぎつけたってシロモノです。

    追記:2012/6/2
    エラーが出た時にはこちらが参考になります。
    MySQL の INSTALL PLUGIN に失敗する時の処方箋(mroonga-1.20編) – よし研 -日々クリエイション-

    また、mroongaはHomebrewでインストールできるようになったみたいです。こちらの方が簡単でしょう。MacPorts使っているボクは負けg(ry
    mroonga 2.03リリース


    Filed under: Mac,MySQL,インストールメモ,開発環境

    Trackback Uri






    2012年 4月 5

    ローカル環境とリモート環境の準備

    ようやくgitを少しずつ使い出してみたもののデプロイするにはどうすればいいのか分からなかったのでとりあえず作業内容をメモしておく。

    • ローカル:mac OSX 10.6
    • リモートサーバ:CentOS 5.5

    公開鍵方式でSSHにログイン出来るようにする

    ローカル環境での操作

    ターミナルでログインし、ホームディレクトリで秘密鍵と公開鍵のペアを作成する。RSA方式でよいと思われる。

    MacBook:~ clicktx$ ssh-keygen -t rsa
    Generating public/private rsa key pair.
    Enter file in which to save the key (/Users/clicktx/.ssh/id_rsa): [enter]
    Enter passphrase (empty for no passphrase): [enter]
    Enter same passphrase again: [enter]
    Your identification has been saved in /Users/clicktx/.ssh/id_rsa.
    Your public key has been saved in /Users/clicktx/.ssh/id_rsa.pub.
    The key fingerprint is:
    01:0a:3b:c1:1c:7f:2e:1c:5d:ae:1b:16:59:70:ef:fd clicktx@MacBook.local
    The key's randomart image is:
    +--[ RSA 2048]----+
    | o+.  o.+        |
    |  o= o B .       |
    |  o + = o .      |
    |   o + o o .     |
    |    o = S . .    |
    |     o o     .   |
    |      .       E  |
    |                 |
    |                 |
    +-----------------+

    id_rsa … 秘密鍵
    id_rsa.pub … 公開鍵

    秘密鍵と公開鍵のペアがホームディレクトリの.ssh/以下に作成される。

    公開鍵である id_rsa.pub をリモートサーバのホームディレクトリにアップロードする。
    個人的にリモートサーバのSSHはポート番号を変更しているため以下のような[-P ポート番号]オプションをつけている。

    $ cd ~/.ssh
    $ scp -P ポート番号 id_rsa.pub clicktx@domain.com:~/
    clicktx@domain.com's password: 
    id_rsa.pub                                    100%  405     0.4KB/s   00:00 

    リモートサーバでの操作

    ホームディレクトリに.sshディレクトリが無ければ作成する。

    $ mkdir ~/ .ssh
    $ chmod 700 .ssh/ (自分だけ読み書き出来る)

    id_rsa.pubの内容を.ssh/authorized_keysに追加する

    $ cat id_rsa.pub >> ~/.ssh/authorized_keys
    $ cd .ssh/
    $ chmod 600 authorized_keys (自分だけ読み書き出来る)
    $ rm ~/id_rsa.pub (不要になったid_rsa.pubを削除しておく)

    ローカル端末からの操作

    新しいターミナルからログインしてみる。

    $ ssh -p ポート番号 clicktx@domain.com
    Last login: Thu Nov 24 10:12:16 2011 from xxxxxx.xxx.xxx.xx.jp

    公開鍵作成時にパスフレーズは設定していないので、何も聞かれずにログイン出来れば成功。

     


     

    リモートサーバにgitをインストール

    CentOSのデフォルトリポジトリではgitが提供されていない。
    rpmforgeリポジトリを導入していればyumで一発でインストールできる。

    $ sudo yum install git

    gitの環境設定

    ユーザー名とメールアドレスを設定。

    $ git config --global user.name "clicktx"
    $ git config --global user.email clicktx@domain.com

    git pushした時にデプロイされるようにする

    ローカルで開発した内容をデプロイする時にgit pushで済むようにする。

    仕組み的には

    bareリポジトリにpush
    ↓
    デプロイ先のリポジトリがbareリポジトリからpull
    ↓
    ワークツリーに反映される

    こんな感じみたい。なるほど。

    作業自体はこんな感じ

    リモートでの作業
    ・リモートサーバにbareリポジトリを作る(push先)
    ・フックを仕掛ける
    ・デプロイ先(公開ディレクトリ)にgitリポジトリを作る
    
    ローカルでの作業
    ・リモートリポジトリの登録
    リモートでの作業

    リモートサーバにbareリポジトリを作る

    $ mkdir ~/repos
    $ cd ~/repos
    $ mkdir mysite.git
    $ cd mysite.git
    $ git init --bare

    フックを仕掛ける
    post-receive.sampleのシェルスクリプトをコピーしてpost-receiveを作成する。実行権を与える。

    単にpullしたいリポジトリがあるディレクトリに移動してpullを実行させるだけ。

    $ cd ~/repos/mysite.git
    $ cp hooks/post-receive.sample hooks/post-receive
    $ vi hooks/post-receive
    
    (cd /home/clicktx/www/mysite; git --git-dir=.git pull)  # 最終行に追記する
    
    $ chmod +x ~/repos/mysite.git/hooks/post-receive

    デプロイ先(公開ディレクトリ)にgitリポジトリを作る(cloneする)
    ここでは ~/www/mysite

    $ mkdir ~/www
    $ cd ~/www
    $ git clone ~/repos/mysite.git/
    
    ローカルでの作業

    すでにgitリポジトリがあるものとする。

    リモートリポジトリの登録

    $ cd ~/Work/mysite
    $ git remote add origin ssh://clicktx@domain.com:ポート番号/~/repos/mysite.git

    pushしてみる。2回目からはgit pushのみで行える。

    $ git push origin master
    
    ...色々変更
    git commit -a
    git push

    これでおれおれバージョン管理システムとはお別れ…かな?

    参考:


    Filed under: Mac,プログラミング,開発環境

    Trackback Uri






    2011年 12月 18

    バージョン管理もそろそろしてみようということでgitを選択。分散型でいいらしい。git自体まだ分かっていないけど、github使ってみようという試み。

    環境:mac OSX 10.6

    公開鍵方式でSSHログイン出来るようにする

    どうやらgithubにpushするにはSSH公開鍵を登録する必要がある様子。なので、秘密鍵と公開鍵のペアの作成から。

    秘密鍵と公開鍵のペアを作成

    ターミナルで秘密鍵と公開鍵のペアを作成する。RSA方式でよいと思われる。
    作業する場所はユーザーのホームディレクトリ。

    ターミナルで ssh-keygen -t rsa で作成できる。
    パスフレーズは空でenterする。

    .. continue reading ..


    Filed under: プログラミング,開発環境

    Trackback Uri