不久的学习笔记。分享。我想有很大的帮助谁刚开始学习其他人的
备注:该票据于mysql-5.1.73版本号例如
1. mysql源代码编译/安装步骤
1) 官网下载mysql源代码并解压
2) cd至源代码文件夹。运行
./configure --prefix=/home/slvher/tools/mysql-5.1.73 --with-charset=gbk --with-charset=gb2312 --with-extra-charsets=all --with-plugins=max-no-ndb备注:
--prefix指定安装文件夹,需依据实际情况改动
--with-charset指定默认支持的字符集,可指定多个(若须要数据库支持中文简体,请务必指定gbk和gb2312,至少要指定1个)
--with-plugins指定安装innodb引擎(从mysql5.1版本号開始须要手动指定,之前则是默认安装的)
3) 查看Makefile文件。确认几个基本配置无误后,运行
shell> make shell> make install备注1:若install失败是由第2步运行./configure时參数指定错误所致,则需又一次运行./configure且务必运行make clean后。再又一次make && make install。
若不先make clean直接make,则源代码文件夹下上次编译完的部分文件不会又一次编译,而这些上次编译的文件使用的还是上次的错误配置參数!
4) 从源代码文件夹的support-files文件夹拷贝my-medium.cnf(共同拥有small/medium/large三个level。依据机器配置选择合适的)配置至~/.my.cnf文件,并配置相关參数。mysql server启动时会读取该文件的配置,关于mysql对my.cnf文件的搜索路径,能够查看官方的mysql-refman文档。
5) 在mysql安装文件夹先后运行例如以下命令以便安装权限表及默认数据库
./bin/mysql_install_db --basedir=/home/slvher/tools/mysql-5.1.73 --datadir=/home/slvher/tools/mysql-5.1.73/db-data ./bin/mysql_install_db --user=slvher6) 在mysql安装文件夹运行例如以下命令启动mysqld:
./bin/mysqld_safe &7) 运行ps -x查看mysqld是否启动成功,当中d表示守护模式。因此。正常的关闭mysqlserver的方法应该是以下的命令:
./bin/mysqladmin shutdown -uroot -p然后输入rootpassword就可以停掉mysqld进程,若强行kill -9杀进程可能会导致数据库损坏!
8) 将mysql运行路径增加PATH变量的搜索路径
至此,支持中文gbk和gb2312的mysql server安装完毕。可运行下面命令验证其支持的字符集:
shell> mysql -uroot mysql> show character set;备注1:新安装的mysql server。root默认password为空
备注2:若在第2步运行./configurer时通过--with-charset參数指定了gbk或gb2312,则show的输出应该能看到这些字符集,否则,就准备又一次安装一遍吧 -_-
2. 安装完毕并启动mysqld_safe后的訪问权限配置
1) 设定mysql server的rootpassword
rootpassword默觉得空(因此,执行mysql -uroot可直接登录。此外,登录后执行"select User, Host, Password from mysql.user"能够看到root的Password那个字段为空)。所以须要设定rootpassword,方法有几种:
a. 使用set password语句:
shell> mysql -u root mysql> set password for 'root'@'localhost' = PASSWORD('xxx'); # 当中xxx为新密码 mysql> set password for 'root'@'host_name' = PASSWORD('xxx'); # 当中host_name为机器名 mysql> set password for 'root'@'127.0.0.1' = PASSWORD('xxx');b. 使用update语句:
shell> mysql -u root mysql> update mysql.user set Password = PASSWORD('xxx') where User = 'root'; mysql> flush privileges; # 该语句会让mysql server又一次读取权限表若root相应的Host字段有多个。则推荐使用这样的方法指定rootpassword,由于它明显更简洁。
c. 使用mysqladmin工具:
shell> mysqladmin -u root password "xxx" shell> mysqladmin -u root -h host_name passord "xxx"这样的方法无法设定形如'root'@'127.0.0.1'的root新密码,故个人认为用处不大。
注意:新安装的mysql server默认同意本机匿名用户登录,若不须要。最好删除匿名用户。
2) 加入新用户并授权
因为root权限过大,有必要为mysql加入normal user并设定其权限。可通过下面步骤实现(如果已登录了mysql server所在机器):
shell> mysql -u root -pxxx # 注意-p与password(如果为"xxx")间无空格。可省去输入password的交互过程 mysql> create user work; mysql> grant select on db1.test_table to 'user'@'localhost' identified by 'xxx';上述grant语句运行效果:从localhost登录的user必须用xxxpassword才干登录成功。且仅仅能訪问数据库db1的test_table表。
若要为从localhost登录的user授权对全部库全部表的全部操作权限,则可运行例如以下命令:
mysql> grant all privileges on *.* to 'user'@'localhost' identified by 'xxx';若为远程登录的用户授权(对db1.test_table的select/insert权限),则需运行以下的命令:
mysql> grant select, insert on db1.test_table to 'user'@'%' identified by 'xxx';上述语句中的'%'表示随意主机,因此能够覆盖远程登录的情况。
注意1:有时对远程登录用户授权时会发现,即使运行了上述命令,用户依旧无法远程登录。
这样的情况通常是因为该username首先命中了权限表的某条不支持远程登录的记录(如不同意来自某个IP地址的用户登录)。排查问题时,可运行select User, Host, Password from mysql.user where User = 'user'以查看user用户眼下拥有的权限,定位其是否具有从随意机器登录的权限或是否某个记录明白指定了user用户不能从某台特定的机器登录。
【參考资料】
1.
mysql reference manual
2. mysql: unknown variable 'character-set-server=utf8'解决方法
========================= EOF ==========================
版权声明:本文博客原创文章,博客,未经同意,不得转载。