首先在menuconfig中配置mysql,具體是在Utilities->database->mysql-server。這樣直接編譯就可以了,不過這樣默認是不支持innodb存儲引擎的,估計是考慮openwrt一般是運行的硬件有關,不需要這麼復雜的存儲引擎(占用空間也比MyISAM存儲引擎大)。但是,如果需要支持innodb存儲引擎該怎麼辦?這類型的網上帖子不多,我是之前參照國外的論壇加自己測試得出的。
Openwrt支持innodb存儲引擎
修改feeds/oldpackages/libs/mysql/Makefile
在--with-server之前加--with-innodb
修改feeds/oldpackages/libs/mysql/conf/my.cnf
在[mysqld]中加default-storage-engine=INNODB
在bind-address = 127.0.0.1下載添加
innodb
innodb_file_per_table = 1
innodb_flush_log_at_trx_commit = 2
/etc/init.d/mysqld腳本start函數中添加
start() { local datadir=$(sed -n -e "s/^[[:space:]]*datadir[[:space:]]*=[[:space:]]*[\"']\?\([^\"']*\)[\"']\?/\1/p" /etc/my.cnf) local mysqldatadir="/mnt/data/mysql/" local mysqltmpdir="/mnt/data/tmp/" local mysqlsrvdir="/srv/mysql/" if [ ! -d "$mysqldatadir" ]; then echo "create dir /mnt/data/mysql/..." mkdir -p "$mysqldatadir" fi if [ ! -d "$mysqltmpdir" ]; then echo "create dir /mnt/data/tmp/..." mkdir -p "$mysqltmpdir" fi if [ ! -d "$mysqlsrvdir" ]; then echo "create dir /srv/mysql/..." mkdir -p "$mysqlsrvdir" fi if [ ! -d "$datadir" ]; then error "Error: datadir '$datadir' in /etc/my.cnf doesn't exist" return 1 fi if [ ! -f "$datadir/mysql/tables_priv.MYD" ]; then mysql_install_db --force service_stop /usr/bin/mysqld #error "Error: I didn't detect a privileges table, you might need to run mysql_install_db --force to initialize the system tables" #return 1 fi service_start /usr/bin/mysqld }至此,基於innodb的MySQL就可以正常運行了。
上述這個莫名其妙的問題經過驗證確實是由於flash空間不夠引起的。解決的辦法是,在路由器上掛載一個U盤。掛載U盤的配置項為:
kernel modules ->filesystems->kmod-fs-vfat
kernel modules->native language support->kmod-nls-cp437/kmod-nls-iso8859-1/kmod-nls-utf-8
kernel modules->usb support->kmod-usb-core/kmod-usb-ohci/kmod-usb-storage/kmod-usb-usb2
。
還有,在init初始化腳本中如果順序執行多個mysql操作的時候,如mysql_install_db --force命令之後接著mysqladmin -u root password '123456'則可能會失敗,因為還沒等mysql_install_db執行完成就會執行mysqladmin命令。解決此問題的辦法是加sleep時間,具體多長時間可以視情況而定。