/***********************************************************************
*        buildroot mysql mysql.mk hacking
* 说明:
* 大致看一下buildroot中mysql是如何进行配置,主要是看运行./configure
* 的时候配置,有时候配置buildroot的时候,有些选项不知道,也可以到这些
* mk文件去看看,这样就知道在make menuconfig中打开什么选项了。
*
* 2017-2-10 深圳 南山平山村 曾剑锋
**********************************************************************/ ################################################################################
#
# mysql
#
################################################################################ # mysql主版本号
MYSQL_VERSION_MAJOR = 5.1
# mysql次版本号+次版本号
MYSQL_VERSION = $(MYSQL_VERSION_MAJOR).
# mysql源代码包名称
MYSQL_SOURCE = mysql-$(MYSQL_VERSION).tar.gz
# mysql源代码路径
MYSQL_SITE = http://dev.mysql.com/get/Downloads/MySQL-$(MYSQL_VERSION_MAJOR)
MYSQL_INSTALL_STAGING = YES
MYSQL_DEPENDENCIES = readline ncurses
MYSQL_AUTORECONF = YES
MYSQL_LICENSE = GPLv2
MYSQL_LICENSE_FILES = README COPYING # Unix socket. This variable can also be consulted by other buildroot packages
MYSQL_SOCKET = /run/mysql/mysql.sock MYSQL_CONF_ENV = \
ac_cv_sys_restartable_syscalls=yes \
ac_cv_path_PS=/bin/ps \
ac_cv_FIND_PROC="/bin/ps p \$\$PID | grep -v grep | grep mysqld > /dev/null" \
ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_GCC=yes \
ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS=no \
ac_cv_have_decl_HAVE_IB_GCC_ATOMIC_BUILTINS=yes \
mysql_cv_new_rl_interface=yes MYSQL_CONF_OPTS = \
--without-ndb-binlog \
--without-docs \
--without-man \
--without-libedit \
--without-readline \
--with-low-memory \
--enable-thread-safe-client \
--with-unix-socket-path=$(MYSQL_SOCKET) \
--disable-mysql-maintainer-mode # host-mysql only installs what is needed to build mysql, i.e. the
# gen_lex_hash tool, and it only builds the parts that are needed to
# create this tool
HOST_MYSQL_DEPENDENCIES = host-zlib host-ncurses HOST_MYSQL_CONF_OPTS = \
--with-embedded-server \
--disable-mysql-maintainer-mode define HOST_MYSQL_BUILD_CMDS
$(HOST_MAKE_ENV) $(MAKE) -C $(@D)/include my_config.h
$(HOST_MAKE_ENV) $(MAKE) -C $(@D)/mysys libmysys.a
$(HOST_MAKE_ENV) $(MAKE) -C $(@D)/strings libmystrings.a
$(HOST_MAKE_ENV) $(MAKE) -C $(@D)/vio libvio.a
$(HOST_MAKE_ENV) $(MAKE) -C $(@D)/dbug libdbug.a
$(HOST_MAKE_ENV) $(MAKE) -C $(@D)/regex libregex.a
$(HOST_MAKE_ENV) $(MAKE) -C $(@D)/sql gen_lex_hash
endef define HOST_MYSQL_INSTALL_CMDS
$(INSTALL) -m $(@D)/sql/gen_lex_hash $(HOST_DIR)/usr/bin/
endef ifeq ($(BR2_PACKAGE_OPENSSL),y)
MYSQL_DEPENDENCIES += openssl
endif ifeq ($(BR2_PACKAGE_ZLIB),y)
MYSQL_DEPENDENCIES += zlib
endif ifeq ($(BR2_PACKAGE_MYSQL_SERVER),y)
MYSQL_DEPENDENCIES += host-mysql host-bison MYSQL_CONF_OPTS += \
--localstatedir=/var/mysql \
--with-atomic-ops=up \
--with-embedded-server \
--without-query-cache \
--without-plugin-partition \
--without-plugin-daemon_example \
--without-plugin-ftexample \
--without-plugin-archive \
--without-plugin-blackhole \
--without-plugin-example \
--without-plugin-federated \
--without-plugin-ibmdb2i \
--without-plugin-innobase \
--without-plugin-innodb_plugin \
--without-plugin-ndbcluster # Debugging is only available for the server, so no need for
# this if-block outside of the server if-block
ifeq ($(BR2_ENABLE_DEBUG),y)
MYSQL_CONF_OPTS += --with-debug=full
else
MYSQL_CONF_OPTS += --without-debug
endif define MYSQL_USERS
mysql - nogroup - * /var/mysql - - MySQL daemon
endef define MYSQL_ADD_FOLDER
$(INSTALL) -d $(TARGET_DIR)/var/mysql
endef MYSQL_POST_INSTALL_TARGET_HOOKS += MYSQL_ADD_FOLDER # 安装mysql的SysV开机自启动文件
define MYSQL_INSTALL_INIT_SYSV
$(INSTALL) -D -m package/mysql/S97mysqld \
$(TARGET_DIR)/etc/init.d/S97mysqld
endef # 安装mysql的Systemd开机自启动文件
define MYSQL_INSTALL_INIT_SYSTEMD
$(INSTALL) -D -m package/mysql/mysqld.service \
$(TARGET_DIR)/usr/lib/systemd/system/mysqld.service
mkdir -p $(TARGET_DIR)/etc/systemd/system/multi-user.target.wants
ln -sf ../../../../usr/lib/systemd/system/mysqld.service \
$(TARGET_DIR)/etc/systemd/system/multi-user.target.wants/mysqld.service
endef else
MYSQL_CONF_OPTS += \
--without-server
endif define MYSQL_REMOVE_TEST_PROGS
rm -rf $(TARGET_DIR)/usr/mysql-test $(TARGET_DIR)/usr/sql-bench
endef MYSQL_POST_INSTALL_TARGET_HOOKS += MYSQL_REMOVE_TEST_PROGS $(eval $(autotools-package))
$(eval $(host-autotools-package))

最新文章

  1. T-Sql编程基础
  2. 在iOS APP中使用H5显示百度地图时如何支持HTTPS?
  3. 部署额外域控制器,Active Directory
  4. tomcat的部署
  5. 算法系列3《SHA》
  6. 【LeetCode题意分析&解答】40. Combination Sum II
  7. Date 和 SimpleDateFormat 类表示时间
  8. 关于DatePicker在模态窗体下失效的问题
  9. <玩转Django2.0>读书笔记:模板和模型
  10. SQL语句练习题【主供自己学习、记忆】
  11. 爬虫之scrapy扩展
  12. (8)Jquery1.8.3快速入门_可见性选择器
  13. Makes And The Product CodeForces - 817B (思维+构造)
  14. MySQL随记(一)
  15. Unity3D中的生命周期函数
  16. mysql启动时报错:Starting MySQL... ERROR! The server quit without updating PID file (/opt/mysql/data/mysql.pid)
  17. 大话存储 1 - 走进计算机IO世界
  18. 二叉查找树ADT--C语言描述
  19. 【jQuery】cookie插件
  20. 权限项目总结(四) shiro 授权

热门文章

  1. ios json结构
  2. 第三方-Swift2.0后Alamofire的使用方法
  3. Laravel开发:多用户登录验证(1)
  4. Visual Studion 2013 HTML 如何打开设计图
  5. windows10系统自带输入法不能切换中文如何解决
  6. java中业务接口
  7. java.time.format.DateTimeFormatter
  8. centos7安装 go
  9. [Symfony\Component\Config\Definition\Exception\InvalidConfigurationException] The child node "db_driver" at path "fos_user" must be configured.
  10. 【转载】Java定时器的学习