1 # -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ #安装路径 2 # -DMYSQL_DATADIR=/usr/local/mysql/data \ #数据文件存放位置 3 # -DSYSCONFDIR=/etc \ #my.cnf路径 4 # -DWITH_MYISAM_STORAGE_ENGINE=1 \ #支持MyIASM引擎 5 # -DWITH_INNOBASE_STORAGE_ENGINE=1 \ #支持InnoDB引擎 6 # -DWITH_MEMORY_STORAGE_ENGINE=1 \ #支持Memory引擎 7 # -DWITH_READLINE=1 \ #快捷键功能(我没用过) 8 # -DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \ #连接数据库socket路径 9 # -DMYSQL_TCP_PORT=3306 \ #端口 10 # -DENABLED_LOCAL_INFILE=1 \ #允许从本地导入数据 11 # -DWITH_PARTITION_STORAGE_ENGINE=1 \ #安装支持数据库分区 12 # -DEXTRA_CHARSETS=all \ #安装所有的字符集 13 # -DDEFAULT_CHARSET=utf8 \ #默认字符 14 # -DDEFAULT_COLLATION=utf8_general_ci \ #校验字符
创建用户及用户组 [root@end mysql]# groupadd mysql 创建mysql组 [root@end mysql]# useradd -r -g mysql mysql 创建mysql用户并添加到mysql组 修改目录所有者和所有组 [root@end mysql]#chown -R mysql:mysql /usr/local/mysql 将mysql目录下的所有文件的所有者和所有组改为msyql 初始化数据库 [root@end mysql]# scripts/mysql_install_db --user=mysql --datadir=/usr/local/mysql/data/ 复制mysql服务启动配置文件(注意:在CentOS 6.4版操作系统的最小安装完成后,在/etc目录下会存在一个my.cnf,需要将此文件更名为其他的名字,如:/etc/my.cnf.bak,否则,该文件会干扰源码安装的MySQL的正确配置,造成无法启动) [root@end mysql]# cp /usr/local/mysql/support-files/my-medium.cnf /etc/my.cnf 注册为服务 [root@end mysql]# cp /usr/local/mysql/support-files/mysql.server /etc/rc.d/init.d/mysqld 将mysqld添加为服务 让chkconfig管理mysql服务 [root@end mysql]# chkconfig --add mysqld 将mysqld服务添加到chkconfig中 [root@end mysql]# chkconfig mysqld on 重启系统后服务自动运行 设置环境变量 在文件/etc/profile末尾添加 PATH=/usr/local/mysql/bin:$PATH [root@end mysql]# source /etc/profile 使修改的环境变量立即生效 启动mysql服务 [root@end mysql]# service mysqld start Starting MySQL... [确定] 检查mysql服务是否启动 [root@end mysql]# netstat -tulnp |grep 3306 tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 24351/mysqld 查看mysql相关进程 [root@localhost ncurses-6.0]# ps aux |grep mysql root 48813 0.0 0.3 11304 1492 pts/2 S 16:47 0:00 /bin/sh /usr/local/mysql/bin/mysqld_safe --datadir=/usr/local/mysql/data --pid-file=/usr/local/mysql/data/localhost.localdomain.pid mysql 48979 0.0 9.8 413156 37360 pts/2 Sl 16:47 0:00 /usr/local/mysql/bin/mysqld --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --plugin-dir=/usr/local/mysql/lib/plugin --user=mysql --log-error=/var/log/mysqld.log --pid-file=/usr/local/mysql/data/localhost.localdomain.pid --socket=/var/lib/mysql/mysql.sock root 49018 0.0 0.2 103304 892 pts/2 S+ 16:53 0:00 grep mysql 修改mysql用户root密码 [root@end mysql]# mysql -uroot 登录到mysql,首次登陆无密码 mysql> SET PASSWORD = PASSWORD('endmoon'); 设置mysql密码 Query OK, 0 rows affected (0.00 sec) 用设置的密码登录到mysql数据库 [root@end mysql]# mysql -u root -p Enter password: endmoon 若要设置root用户可以远程访问,执行 mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.1.20' IDENTIFIED BY 'password' WITH GRANT OPTION; Query OK, 0 rows affected (0.00 sec) 配置防火墙 防火墙的3306端口默认没有开启,若要远程访问,需要开启这个端口 打开/etc/sysconfig/iptables,在-A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT后面添加 -A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT [root@end mysql]# service iptables restart 使更改的防火墙配置生效 iptables:将链设置为政策 ACCEPT:filter [确定] iptables:清除防火墙规则: [确定] iptables:正在卸载模块: [确定] iptables:应用防火墙规则: [确定] 那么mysql数据库的源码安装到这里就结束了
转载于:https://www.cnblogs.com/endmoon/articles/5275795.html