Home >Database >Mysql Tutorial >How to install mysql source code package
Mysql source code package installation method: first upload or download the source code package and install the dependencies; then decompress the installation package and generate it; then compile and install, make soft connections, create users, copy configuration files and startup scripts , initialize the database, etc.; finally start the database and configure environment variables, and confirm the startup.
More related free learning recommendations: mysql tutorial(video)
mysql source package installation method:
Source package installation
1) Upload or download the source package
[root@db02 ~]# rz mysql-5.6.46.tar.gz
2) Install dependencies
Due to different installation environments, other errors may be reported during the generation process. Just follow the error prompts to install the corresponding Yina package.
[root@db02 ~]# yum install -y ncurses-devel libaio-devel gcc gcc-c++ glibc cmake autoconf openssl openssl-devel
3) Unzip the installation package
[root@db02 ~]# tar xf mysql-5.6.46.tar.gz
4) Generate
[root@db02 ~]# cd mysql-5.6.46/ [root@db02 mysql-5.6.46]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql-5.6.46 \ -DMYSQL_DATADIR=/usr/local/mysql-5.6.46/data \ -DMYSQL_UNIX_ADDR=/usr/local/mysql-5.6.46/tmp/mysql.sock \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci \ -DWITH_EXTRA_CHARSETS=all \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_FEDERATED_STORAGE_ENGINE=1 \ -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \ -DWITH_ZLIB=bundled \ -DWITH_SSL=system \ -DENABLED_LOCAL_INFILE=1 \ -DWITH_EMBEDDED_SERVER=1 \ -DENABLE_DOWNLOADS=1 \ -DWITH_DEBUG=0
5) Compile and install
[root@db02 mysql-5.6.46]# make && make install
6) Make a soft link
[root@db02 ~]# ln -s /usr/local/mysql-5.6.46 /usr/local/mysql
7) Create user
[root@db02 ~]# useradd mysql -s /sbin/nologin -M
8) Copy configuration file and startup script
[root@db02 ~]# cd /usr/local/mysql/support-files/ [root@db02 support-files]# cp my-default.cnf /etc/my.cnf cp: overwrite '/etc/my.cnf'? y [root@db02 support-files]# cp mysql.server /etc/init.d/mysqld
9) Initialize database
[root@db02 support-files]# cd /usr/local/mysql/scripts/ [root@db02 scripts]# ./mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
8) Configure system management mysql
[root@db02 scripts]# vim /usr/lib/systemd/system/mysqld.service [Unit] Description=MySQL Server Documentation=man:mysqld(8) Documentation=https://dev.mysql.com/doc/refman/en/using-systemd.html After=network.target After=syslog.target [Install] WantedBy=multi-user.target [Service] User=mysql Group=mysql ExecStart=/usr/local/bin/mysqld --defaults-file=/etc/my.cnf LimitNOFILE = 5000 [root@db02 scripts]# systemctl daemon-reload [root@db02 scripts]# systemctl start mysqld
9) Error when startup fails
[root@db02 scripts]# /etc/init.d/mysqld start Starting MySQL.Logging to '/usr/local/mysql-5.6.46/data/db02.err'. 200709 15:42:14 mysqld_safe Directory '/usr/local/mysql-5.6.46/tmp' for UNIX socket file don't exists. ERROR! The server quit without updating PID file (/usr/local/mysql-5.6.46/data/db02.pid). #原因: 1.cmake过程指定了socket文件位置,实际位置不存在 2.目录权限不足 #解决: [root@db02 scripts]# mkdir /usr/local/mysql-5.6.46/tmp/ [root@db02 scripts]# chown -R mysql.mysql /usr/local/mysql [root@db02 scripts]# chown -R mysql.mysql /usr/local/mysql-5.6.46/
10) Start database
[root@db02 scripts]# systemctl start mysqld
11) Configure environment variables
[root@db03 scripts]# vim /etc/profile.d/mysql.sh export PATH=/usr/local/mysql/bin:$PATH [root@db03 mysql]# source /etc/profile
12) Confirm startup
[root@m01 scripts]# ps -ef | grep mysql mysql 12886 1 2 03:10 ? 00:00:00 /usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf root 12921 10636 0 03:11 pts/1 00:00:00 grep --color=auto mysql [root@m01 scripts]# netstat -lntp tcp6 0 0 :::3306 :::* LISTEN 12886/mysqld
The above is the detailed content of How to install mysql source code package. For more information, please follow other related articles on the PHP Chinese website!