您好,欢迎访问一九零五行业门户网

CentOS7怎么编译安装MySQL 8.0

centos编译安装mysql的教程网上有很多,基本上大同小异。但是安装软件有时就可能因为一个细节安装失败。
0.前期准备条件
•查看linux的版本
[root@mysql etc]# cat /etc/redhat-releasecentos linux release 7.3.1611 (core)•could not find cursesyum install ncurses-devel•bison executable not found in pathyum install bison
备注: 安装过程中会缺少基础包,本实例环境缺少上述包,先提前安装相应的包
1.cmake的源编译安装
[root@db software]# nohup tar zxvf cmake-3.11.1.tar.gz &[root@db software]# cd cmake-3.11.1[root@db cmake-3.11.1]# ./configure[root@localhost cmake-3.0.1]# gmake && make install
2.wolfssl包的部署安装[可选项]
*. 从wolfssl.com网站下载wolfssl-3.13.0.zip压缩包*. 解压至/data/software/mysql-8.0.11/extra/wolfssl-3.13.0目录中。*. cd extra/wolfssl-3.13.0/ide/mysql*. 执行do.sh脚本*. use -dwith_ssl=wolfssl for cmake
3.openssl和openssl-devel[本实验使用的是system ssl]
yum install –y openssl openssl-devel
4.mysql的编译安装
[root@mysql software]#tar zxvf mysql-8.0.11.tar.gz[root@mysql software]# cd mysql-8.0.11/[root@mysql software]# mkdir zdebug[root@mysql software]# cd zdebugcmake .. -dcmake_install_prefix=/usr/local/mysql \-ddefault_charset=utf8 \-ddefault_collation=utf8_general_ci \-denabled_local_infile=on \-dwith_innodb_memcached=on \-dwith_ssl=system \-dwith_innobase_storage_engine=1 \-dwith_federated_storage_engine=1 \-dwith_blackhole_storage_engine=1 \-dwith_archive_storage_engine=1 \-dwithout_example_storage_engine=1 \-dwith_perfschema_storage_engine=1 \-dcompilation_comment="zsd edition" \-ddownload_boost=1 \-dwith_boost=/tmp \-dmysql_unix_addr=/data/mysqldata/3306/mysql.sock \-dsysconfdir=/data/mysqldata/3306 > /data/software/mysql-8.0.11/zdebug/mysql_cmake80.log 2>&1
出现下列日志:
............-- configuring done-- generating done-- build files have been written to: /data/software/mysql-8.0.11/zdebug............
说明编译成功,其中-dwith_ssl=system用的是linux操作系统的openssl,需要安装openssl和openssl-devel包,才可以被编译
如果需要编译安装快速,可以运用多线程加快编译安装,命令如下:
make -j 12make install
•mysql 8.0的软件目录结构
[root@mysql zdebug]# cd /usr/local/mysql/[root@mysql mysql]# ls -ltotal 612drwxr-xr-x. 2 root root 4096 may 16 14:20 bindrwxr-xr-x. 2 root root 55 may 16 14:20 docsdrwxr-xr-x. 3 root root 266 may 16 14:20 includedrwxr-xr-x. 4 root root 173 may 16 14:20 lib-rw-r--r--. 1 root root 301518 apr 8 14:44 license-rw-r--r--. 1 root root 301518 apr 8 14:44 license-testdrwxr-xr-x. 4 root root 30 may 16 14:20 mandrwxr-xr-x. 10 root root 4096 may 16 14:21 mysql-test-rw-r--r--. 1 root root 687 apr 8 14:44 readme-rw-r--r--. 1 root root 687 apr 8 14:44 readme-testdrwxr-xr-x. 28 root root 4096 may 16 14:21 sharedrwxr-xr-x. 2 root root 90 may 16 14:21 support-files
5.创建mysql用户&并修改相关文件
[root@mysql mysql]# groupadd mysql[root@mysql mysql]# useradd -g mysql mysql
6.设置用户操作系统资源的限制
[root@localhost cmake-3.0.1]# vi /etc/security/limits.confmysql soft nproc 65536mysql hard nproc 65536mysql soft nofile 65536mysql hard nofile 65536
验证limit是否生效
[root@mysql ~]# su - mysql[mysql@mysql ~]$ ulimit -a
日志如下:
open files (-n) 65536max user processes (-u) 65536............
7.创建mysql数据目录及赋予相应权限
#cd /data/#mkdir -p /data/mysqldata/{3306/{data,tmp,binlog,innodb_ts,innodb_log},backup,scripts}#chown -r mysql:mysql mysqldata#su - mysql
8.配置my.cnf文件
$vi /data/mysqldata/3306/my.cnf[client]port = 3306socket = /data/mysqldata/3306/mysql.sock# the mysql server[mysqld]port = 3306user = mysqlsocket = /data/mysqldata/3306/mysql.sockpid-file = /data/mysqldata/3306/mysql.pidbasedir = /usr/local/mysqldatadir = /data/mysqldata/3306/datatmpdir = /data/mysqldata/3306/tmpopen_files_limit = 60000explicit_defaults_for_timestampserver-id = 1203306lower_case_table_names = 1character-set-server = utf8federated#sql_mode=strict_trans_tablesmax_connections = 1000max_connect_errors = 100000interactive_timeout = 86400wait_timeout = 86400sync_binlog=0back_log=100default-storage-engine = innodblog_slave_updates = 1#*********** logs related settings ***********log-bin = /data/mysqldata/3306/binlog/mysql-binbinlog_format= mixedbinlog_cache_size=32mmax_binlog_cache_size=64mmax_binlog_size=512mlong_query_time = 1log_output = filelog-error = /data/mysqldata/3306/mysql-error.logslow_query_log = 1slow_query_log_file = /data/mysqldata/3306/slow_statement.log#log_queries_not_using_indexesgeneral_log = 0general_log_file = /data/mysqldata/3306/general_statement.log#expire-logs-days = 14binlog_expire_logs_seconds = 1728000relay-log = /data/mysqldata/3306/binlog/relay-binrelay-log-index = /data/mysqldata/3306/binlog/relay-bin.index#****** mysql replication new feature*********master-info-repository=tablerelay-log-info-repository=tablerelay-log-recovery#*********** innodb specific options ***********innodb_buffer_pool_size = 2048mtransaction-isolation=repeatable-readinnodb_buffer_pool_instances = 8innodb_file_per_table = 1innodb_data_home_dir = /data/mysqldata/3306/innodb_tsinnodb_data_file_path = ibdata1:2048m:autoextendinnodb_thread_concurrency = 8innodb_log_buffer_size = 16minnodb_log_file_size = 128minnodb_log_files_in_group = 3innodb_log_group_home_dir = /data/mysqldata/3306/innodb_loginnodb_flush_log_at_trx_commit = 2innodb_max_dirty_pages_pct = 70innodb_flush_method=o_direct[mysql]no-auto-rehashdefault-character-set=gbkprompt = (\u@\h) [\d]>\_
9.初始化mysql数据库
$/usr/local/mysql/bin/mysqld --defaults-file=/data/mysqldata/3306/my.cnf --initialize --user=mysql
10.启动mysql服务
$/usr/local/mysql/bin/mysqld_safe --defaults-file=/data/mysqldata/3306/my.cnf --user=mysql &
11.登陆数据库
备注:密码来自于error log日志,明细如下:
2018-05-16t07:17:57.335486z 5 [note] [my-010454] [server] a temporary password is generated for root@localhost: jlocal/mysql/bin/mysql -uroot -p'j
12.数据库一些基本权限配置
修改root账号密码:
alter user 'root'@'localhost' identified with sha256_password by 'zsd@7101' password expire interval 360 day;
查看目前的用户账号
(root@localhost) [(none)]> select user,host from mysql.user;+------------------+-----------+| user | host |+------------------+-----------+| mysql.infoschema | localhost || mysql.session | localhost || mysql.sys | localhost || root | localhost |+------------------+-----------+
以上就是centos7怎么编译安装mysql 8.0的详细内容。
其它类似信息

推荐信息