Centos7 FPM 安装mysql8
参考http://tn.51cto.com/article/647
http://www.jb51.net/article/138787.htm
转载:
卸载centos自带的mariadb
rpm -qa mariadb*
rpm -e *** --nodeps
下载mysql 8.0的rpm完整包
wget -O /tmp/mysql-8.0.11-1.el7.x86_64.rpm-bundle.tar https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.11-1.el7.x86_64.rpm-bundle.tar
解压出rpm包
cd /tmp/
tar xvf mysql-8.0.11-1.el7.x86_64.rpm-bundle.tar
yum安装一下net-tools库、perl
yum -y install net-tools*
yum -y install perl
新建用户和用户组
groupadd mysql
useradd -g mysql mysql
依次编译安装(顺序很重要,存在依赖关系)
rpm -ivh mysql-community-common-8.0.11-1.el7.x86_64.rpm
rpm -ivh mysql-community-libs-8.0.11-1.el7.x86_64.rpm
rpm -ivh mysql-community-client-8.0.11-1.el7.x86_64.rpm
rpm -ivh mysql-community-server-8.0.11-1.el7.x86_64.rpm
初始化mysql
mysqld --initialize --user=mysql
启动mysql
systemctl start mysqld
查看是mysql否启动
inux上面:service mysqld status (可能不对,视情况换service mysql status)查看是否启动,或者netstat -tlunp|grep 3306
windows上面:在“cmd”命令行里面输入“ netstat -an|find "3306",如果有这个说明开启了。
查看生成的密码
vim /var/log/mysqld.log
A temporary password is generated for root@localhost: yv)niz-9_E#M
登陆mysql
mysql -u root -p
修改密码:
ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';
flush privileges;
至此MySQL 8.0 安装完成
- 开启mysql的远程登录
-
登录后
show databases; use mysql; 用哪个数据库 updata user set host='%' where user = ‘root'; select user,host from user; clip_image009 clip_image010
11.防火墙操作
启动一个服务:systemctl start firewalld.service
关闭一个服务:systemctl stop firewalld.service
重启一个服务:systemctl restart firewalld.service
显示一个服务的状态:systemctl status firewalld.service
在开机时启用一个服务:systemctl enable firewalld.service
在开机时禁用一个服务:systemctl disable firewalld.service
查看服务是否开机启动:systemctl is-enabled firewalld.service
查看已启动的服务列表:systemctl list-unit-files|grep enabled
查看启动失败的服务列表:systemctl --failed
12、端口操作
添加 firewall-cmd --zone=public --add-port=80/tcp --permanent(--permanent永久生效,没有此参数重启后失效) 重新载入 firewall-cmd –reload
13.添加远程特账号
mysql> create user root@'%' identified by '123456'; Query OK, 0 rows affected (0.08 sec) mysql> grant all privileges on *.* to root@'%'; Query OK, 0 rows affected (0.04 sec) mysql> flush privileges; Query OK, 0 rows affected (0.01 sec) mysql>ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456'; mysql> exit
补充MySQL 8.0的特性:
1、新的系统字典表
整合了存储有关数据库对象信息的事务数据字典,所有的元数据都用InnoDB引擎进行存储
2、支持DDL 原子操作
InnoDB表的DDL支持事务完整性,要么成功要么回滚,将DDL操作回滚日志写入到data dictionary 数据字典表 mysql.innodb_ddl_log 中用于回滚操作
3、安全和用户管理
新增caching_sha2_password认证插件,并且是默认的身份认证插件。性能和安全方面加强
权限支持role
新增密码历史记录功能,限制重复使用以前的密码
4、支持资源管理
支持创建和管理资源组,并允许将服务器运行的线程分配给特定的组,以便线程根据资源组可用的资源执行
5、innodb 增强
自增列优化,修复MySQL的bug#199,该bug导致在DB重启时,MySQL会将表上最大的自增值作为最大值,下次分配是分配max(id)+1,如果是归档表或者其它模式删除数据后,DB系统重启,自增值可能被重用
新增INFORMATION_SCHEMA.INNODB_CACHED_INDEXES,查看每个索引缓存在InnoDB缓冲池中的索引页数
InnoDB临时表都将在共享临时表空间ibtmp1中创建
对于SELECT ... FOR SHARE和SELECT ... FOR UPDATE语句,InnoDB支持NOWAIT和SKIP LOCKED
innodb_undo_tablespaces的最小值为2,并且不再允许将innodb_undo_tablespaces设置为0。 最小值2确保回滚段始终在撤消表空间中创建,而不是在系统表空间中创建
支持 ALTER TABLESPACE ... RENAME TO 语法
新增innodb_dedicated_server,让InnoDB根据服务器上检测到的内存量自动配置innodb_buffer_pool_size,innodb_log_file_size,innodb_flush_method
新增INFORMATION_SCHEMA.INNODB_TABLESPACES_BRIEF视图
新增了动态配置项 innodb_deadlock_detect,用来禁用死锁检查,因为在高并发系统中,当大量线程等待同一个锁时,死锁检查会大大拖慢数据库
支持使用innodb_directories选项在服务器脱机时将表空间文件移动或恢复到新位置
6、MySQL 8.0更好支持文档型数据库和JSON
7、优化
不可见索引,开始支持invisible index,(感觉又和Oracle一样了),在优化SQL的过程中可以设置索引为不可见,优化器变不会利用不可见索引
支持降序索引,可以对索引定义 DESC,之前,索引可以被反序扫描,但影响性能,而降序索引就可以高效的完成
8、支持RANK(), LAG()、NTILE()等函数
9、正则表达式增强,提供了REGEXP_LIKE(),EGEXP_INSTR(), REGEXP_REPLACE(), REGEXP_SUBSTR()等函数
10、新增备份锁,允许在线备份期间的DML,同时防止可能导致快照不一致的操作。 备份锁由LOCK INSTANCE FOR BACKUP和UNLOCK INSTANCE语法支持
11、字符集 默认字符集由latin1变为utf8mb4
12、配置文件增强
MySQL 8.0版本支持在线修改全局参数持久化,通过加上PERSIST关键字,可以将调整持久化到新的配置文件中,再次重启db还可以应用到最新的参数。对于加上 PERSIST 关键字修改参数命令,MySQL系统会生成一个包含json格式数据的 mysqld-auto.cnf 文件,比如执行:
set PERSIST expire_logs_days=10 ; #内存和json文件都修改,重启还生效
set GLOBAL expire_logs_days=10 ; #只修改内存,重启丢失
系统会在数据目录下生成一个包含如下内容的 mysqld-auto.cnf 的文件:
{ "mysql_server": {"expire_logs_days": "10" } }
当 my.cnf 和 mysqld-auto.cnf 同时存在时,后者具有高优先级。
13、直方图
MySQL 8.0 版本开始支持期待已久直方图。优化器会利用column_statistics的数据,判断字段的值的分布,得到更准确的执行计划。
可以使用 ANALYZE TABLE table_name [UPDATE HISTOGRAM on col_name with N BUCKETS |DROP HISTOGRAM ON clo_name] 来收集或者删除直方图信息
14、支持会话级别SET_VAR 动态调整部分参数,有利于提升语句性能。
select /+ SET_VAR(sort_buffer_size = 16M) / id from test order id ;
insert /+ SET_VAR(foreign_key_checks=OFF) / into test(name) values(1);
15、默认参数的调整
调整back_log的默认值,保持和 max_connections一致,增强突发流量带来的连接处理容量。
修改 event_scheduler 默认为ON,之前默认是关闭的。
调整max_allowed_packet 的默认值,从4M增加到64M。
调整bin_log,log_slave_updates默认值为on。
调整expire_logs_days的过期时间为30天,老版本是7天,生产环境时,检查该参数,防止binlog过多造成空间紧张。
调整innodb_undo_log_truncate 默认为ON
调整innodb_undo_tablespaces 默认值为2
调整innodb_max_dirty_pages_pct_lwm 默认值10
调整innodb_max_dirty_pages_pct默认值为90
新增innodb_autoinc_lock_mode 默认值为2
16、InnoDB性能提升
废除buffer pool mutex,将原来一个mutex拆分成多个,提高并发
拆分LOCK_thd_list 和 LOCK_thd_remove 这两个mutex,大约可提高线程链接效率5%。
17、行缓存
MySQL8.0的优化器可以估算将要读取的行数,因此可以提供给存储引擎一个合适大小的row buffer来存储需要的数据。大批量的连续数据扫描的性能将受益于更大的record buffer
18、改进扫描性能
改进InnoDB范围查询的性能,可提升全表查询和范围查询 5-20%的性能。
19、成本模型
InnoDB缓冲区可以估算缓存区中的有多少表和索引,这可以让优化器选择访问方式时知道数据是否可以存储在内存中还是必须存储到磁盘上。
20、重构SQL分析器
改进SQL分析器。旧的分析器由于其语法复杂性和自顶向下的分析方式从而有严重的限制,导致难以维护和扩展。
ALTER
USER
'root'
@
'localhost'
IDENTIFIED
WITH
mysql_native_password(指定密码验证方式)
BY
'新密码'
;
SET
PASSWORD
=
PASSWORD
(
'[修改的密码]'
); 来修改密码
mysql -u root -p
MySQL登录与退出格式
登录Mysql:mysql -u 帐号 -p密码
mysql退出:mysql > exit;
如果有密码的话,登录方式为:
mysql -u root -h 127.0.0.1 -p
至于该使用哪个数据库,使用哪个,应该是这样:
mysql> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| test |
| wt |
+--------------------+
4 rows in set (0.00 sec)
mysql> use test
Database changed
mysql>
mysql -u root -P 3306 -h 127.0.0.1 -p
表示超级用户名root,密码稍后输入,端口号3306(不输入P默认为3306), 主机地址127.0.0.1(若使用本机作为主机,h默认127.0.0.1)
mysql退出三种方法:
mysql > exit;
mysql > quit;
mysql > \q;