动态编译MySQL plugin
經(jīng)常會有人問安裝完了mysql,但是以前沒有安裝XXX?引擎,現(xiàn)在需要在線動態(tài)加載。
對于此問題我自根據(jù)自己的工作總結(jié)了下:
1.使用源碼編譯的,默認innobase沒有被編譯進來;使用二進制包安裝的,在啟動前,在my.cnf里面加入skip-innodb或是ignore_builtin_innodb。
2.使用源碼編譯時,不能使用--with-mysqld-ldflags=-all-static選項,以靜態(tài)方式編譯庫,當show?global?variables?like?'have_%';的時候,輸出有一項是have_dynamic_loading將是NO,這就決定mysql是否支持動態(tài)加載plugin;
而二進制包安裝的mysql,就是動態(tài)編譯的,支持動態(tài)加載plugin,這項為Yes.
這種就不支持動態(tài)加載。
下面的就支持動態(tài)加載:
上面的是沒有編譯時沒有用靜態(tài)編譯,如果上面的plugin_dir?=?/usr/local/mysql/lib/plugin/?下沒有,則拷貝對應(yīng)的文件到這個目錄下。
選擇對應(yīng)的innodb?plugin版本,并將其放到plugin_dir下面,plugin的版本和MySQL庫的對應(yīng)表如下
工作中需要查看編譯時指定了哪些參數(shù):
1、nginx編譯參數(shù):
#/usr/local/nginx/sbin/nginx?-V
2、apache編譯參數(shù):
#?cat?$APACHE_HOME/build/config.nice
3、php編譯參數(shù):
#?/usr/local/php/bin/php?-i?|grep?configure
4、mysql編譯參數(shù):
#?grep?configure?/usr/local/mysql/bin/mysqlbug
?
轉(zhuǎn)載于:https://blog.51cto.com/huanghualiang/1346068
總結(jié)
以上是生活随笔為你收集整理的动态编译MySQL plugin的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: CLR Via CSharp读书笔记(2
- 下一篇: linux cmake编译源码,linu