1.Mysql介绍
MySQL是一个广泛使用的开源关系型数据库管理系统(RDBMS),它基于SQL(Structured Query Language)进行操作。MySQL是由瑞典MySQL AB公司开发的,后来被Sun Microsystems收购,最终成为Oracle公司的产品。由于其性能高、可靠性好、易使用和灵活性强等特点,MySQL在Web应用中尤为流行。
以下是MySQL的一些关键特性:
-
开源:MySQL的社区版是一个开源免费的数据库,适合个人和企业使用。
-
关系型数据库:MySQL使用表格来存储数据,表之间可以通过关联键建立关系。
-
多用户多线程:支持多用户并发访问,提供高性能的数据处理能力。
-
跨平台:可以在多种操作系统上运行,包括Linux、Windows、macOS等。
-
存储引擎:支持多种存储引擎,如InnoDB(支持事务处理和外键)、MyISAM(提供高速存储和检索)等。
-
SQL语言:使用标准的SQL语言进行数据查询和管理。
-
安全性:提供安全功能,如用户认证、访问控制、加密连接等。
-
复制:支持数据复制,可以配置主从复制来提高数据的可用性和冗余。
-
分区:支持数据分区,可以提高大表的管理效率和查询性能。
-
触发器、存储过程和函数:支持复杂的数据操作和自动化任务。
-
持久性和崩溃恢复:具有事务日志和崩溃恢复功能,确保数据的持久性和一致性。
-
性能优化:提供查询缓存、索引、优化器等性能优化工具。
-
易于管理:提供命令行工具和图形用户界面(如phpMyAdmin)来管理数据库。
MySQL适用于各种应用场景,从小型应用到大型企业级应用,都可以见到MySQL的身影。它的高可用性、可扩展性和灵活性使其成为许多开发者和数据库管理员的首选数据库之一。
2.Linux编译安装mysql的难点
在Linux上编译安装MySQL可能会遇到一些难点和常见问题,以下是一些主要的挑战和相应的解决方案:
-
依赖问题:编译MySQL需要安装一系列的依赖包,如
cmake
、ncurses-devel
、openssl-devel
、libarchive
、gcc
、g++
等。缺少这些依赖会导致编译失败。 -
编译选项:使用
cmake
进行编译配置时,需要正确设置编译选项,如指定安装路径、数据目录、字符集等。如果配置不正确,可能会导致编译失败或功能不完整。 -
权限问题:编译安装过程中,需要创建专门的用户和组(通常是
mysql
),并确保数据目录和文件的权限设置正确。权限设置不当可能会导致服务启动失败。 -
初始化问题:MySQL的初始化步骤是编译安装过程中的关键一环,需要确保初始化脚本正确执行。初始化失败可能会导致数据库无法启动。
-
配置文件:需要正确配置
my.cnf
或my.ini
文件,设置端口、字符集、数据目录等。配置错误可能会导致服务无法启动或运行不正常。 -
环境变量:需要配置环境变量,以便在任何目录下都能方便地访问MySQL的命令行工具和其他二进制文件。
-
Boost库:对于MySQL 5.7及以上版本,编译前需要安装Boost库。如果没有正确安装Boost库,编译时会报错。
-
错误处理:编译过程中可能会遇到各种错误,需要根据错误信息进行相应的排查和处理。常见的错误包括缺少依赖、编译器配置错误、文件权限问题等。
-
二进制兼容性:确保下载的MySQL源码与你的操作系统版本和架构兼容。不兼容的版本可能会导致编译失败。
-
服务启动:编译安装完成后,需要启动MySQL服务,并设置开机自启动。这可能需要创建和配置服务脚本。
解决这些问题通常需要一定的Linux系统知识和编译经验。以下是我在操作过程中的一些总结,希望能对大家有所帮助
3.准备工作
3.1 安装cmake
tar -zxvf cmake-3.8.0.tar.gz
cd cmake-3.8.0
./bootstrap
gmake
gmake install
3.2 安装boost_1_59_0
tar -zxvf boost_1_59_0.tar.gz
cd boost_1_59_0
./bootstrap.sh
./b2
./b2 install
3.3.创建用户、配置目录
添加mysql用户和所属组
/usr/sbin/groupadd mysql
/usr/sbin/useradd -g mysql mysql
创建mysql安装目录和数据目录
mkdir /usr/local/mysql
mkdir /usr/local/mysql/data
修改mysql目录所有者
chown -R mysql:mysql /usr/local/mysql
4.安装mysql
tar -zxvf mysql-5.7.14.tar.gz
cd mysql-5.7.14
以下复制到文本中
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local/src/boost_1_59_0 -DMYSQL_UNIX_ADDR=/usr/local/mysql/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DENABLED_LOCAL_INFILE=ON -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_FEDERATED_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 -DWITHOUT_PARTITION_STORAGE_ENGINE=1 -DWITH_FAST_MUTEXES=1 -DWITH_ZLIB=bundled -DENABLED_LOCAL_INFILE=1 -DWITH_READLINE=1 -DWITH_EMBEDDED_SERVER=1 -DWITH_DEBUG=0
make
make install
错误时处理
#mysql安装失败重新编译时,需要清除旧的对象文件和缓存信息
make clean
rm -f CMakeCache.txt
rm -rf /etc/my.cnf
5.配置mysql并初始化数据库
配置文件:
cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf
初始化数据库
./mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data
启动mysql数据库
/usr/local/mysql/bin/mysqld_safe -defaults-file=/etc/my.cnf -basedir=/usr/local/mysql --datadir=/usr/local/mysql/data -user=mysql & ./--mysqld_safe --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql &
查看是否启动
ps -ef | grep mysqld
建立软链接:
ln -s /usr/local/mysql/bin/mysql /usr/bin
6. 修改初始化密码
mysql -u root -p
Set password = password('xxx');
Alter user 'root'@'localhost' password expire never;
grant all privileges on *.* to root@'%' identified by 'xxx';
grant all privileges on *.* to 'root'@'%' identified by 'xxx' with grant option;
Flush privileges;
7.开机启动
touch /usr/lib/systemd/system/mysql.service
设置内容
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://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/mysql/bin/mysqld --defaults-file=/etc/my.cnf
LimitNOFILE = 5000
#Restart=on-failure
#RestartPreventExitStatus=1
#PrivateTmp=false
8.操作命令
systemctl start mysql
systemctl stop mysql
systemctl restart mysql
systemctl disable mysql
systemctl enable mysql
systemctl status mysql
9.最后
感谢大家,请大家多多支持!