Mysql进阶-day2
Mysql cmake方式安装
1.卸载原有mysql下载MySQL安装包
[root@localhost ~]# yum remove mysql* -y
[root@localhost ~]# mkdir /tmp/downloads
[root@localhost ~]# cd /tmp/downloads
[root@localhost downloads]# wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.54.tar.gz
[root@localhost mysql-5.5.54]# userdel mysql
[root@localhost mysql-5.5.54]# groupadd mysql
[root@localhost mysql-5.5.54]# useradd -g mysql -s /sbin/nologin -M mysql
2.解压并安装
[root@localhost downloads]# tar zxf mysql-5.5.54.tar.gz
[root@localhost downloads]# cd mysql-5.5.54
[root@localhost mysql-5.5.54]# yum -y install gcc-c++ cmake ncurses-devel ncurses
[root@localhost mysql-5.5.54]# mkdir -p /data/3306
[root@localhost mysql-5.5.54]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql-5.5.54 \ #安装路径
> -DMYSQL_DATADIR=/data/3306/ \ #数据路径
> -DMYSQL_UNIX_ADDR=/tmp/mysql.sock \ #sockt路径
> -DDEFAULT_CHARSET=utf8 \ #字符集
> -DDEFAULT_COLLATION=utf8_general_ci \ #字符校对规则
> -DENABLED_LOCAL_INFILE=ON \ #
> -DWITH_INNOBASE_STORAGE_ENGINE=1 \ #INNODB存储引擎
> -DWITH_FEDERATED_STORAGE_ENGINE=1 \
> -DIWTH_BLACKHOLE_STORAGE_ENGINE=1 \
> -DWITH_EXAMPLE_STORAGE_ENGINE=1 \
> -DWITH_PARTITION_STORAGE_ENGINE=1
[root@localhost mysql-5.5.54]# make && make install #安装后调整
[root@localhost mysql-5.5.54]# ln -s /usr/local/mysql-5.5.54/ /usr/local/mysql
[root@localhost mysql-5.5.54]# yes|cp support-files/my-small.cnf /etc/my.cnf
[root@localhost mysql-5.5.54]# echo 'export PATH=/usr/local/mysql/bin:$PATH' >> /etc/profile
[root@localhost mysql-5.5.54]# source /etc/profile
[root@localhost mysql-5.5.54]# chown -R mysql.mysql /usr/local/mysql-5.5.54/
[root@localhost mysql-5.5.54]# chown -R mysql.mysql /data/3306/
[root@localhost mysql-5.5.54]# /usr/local/mysql-5.5.54/scripts/mysql_install_db --basedir=/usr/local/mysql-5.5.54/ --datadir=/data/3306/ --user=mysql
[root@localhost mysql-5.5.54]# yes|cp support-files/mysql.server /etc/init.d/mysqld
[root@localhost mysql-5.5.54]# chmod 700 /etc/init.d/mysqld
[root@localhost mysql-5.5.54]# service mysqld start
[root@localhost mysql-5.5.54]# chkconfig mysqld on
优化mysql
1.删除test库(这个库不安全)
mysql> drop database test; 2.删除无关用户和主机名
mysql> select user,host from mysql.user;
+-------------+-----------+
| user | host |
+-------------+-----------+
| root | 127.0.0.1 |
| root | ::1 |
| root | C-server |
| daniel | localhost |
| danieu_tf8l | localhost |
| root | localhost |
+-------------+-----------+
6 rows in set (0.05 sec) mysql> delete from mysql.user; #删除所有用户
mysql> grant all privileges on *.* to system@'localhost' identified by '123'with grant option;
Query OK, 0 rows affected (0.00 sec) #重新取名root并重新赋权 mysql> grant all privileges on *.* to system@'127.0.0.1' identified by '123' with grant option;
Query OK, 0 rows affected (0.00 sec) mysql> select user,host from mysql.user;
+--------+-----------+
| user | host |
+--------+-----------+
| system | localhost |
+--------+-----------+ 1 row in set (0.00 sec)
mysql> select user,host from mysql.user;
+--------+-----------+
| user | host |
+--------+-----------+
| system | 127.0.0.1 |
| system | localhost |
+--------+-----------+
MySQL数据库备份及压缩备份
#备份单个数据库
[root@localhost mysql-5.5.54]# cd /
[root@localhost /]# mkdir /backup #创建备份目录
[root@localhost /]# mysqldump -usystem -p123 -B Daniel >/backup/Daniel_$(date +%F).sql #备份单个数据库,加B比不加多一个创建备份库的命令
[root@localhost /]# egrep -v "^--|\*|^$" /backup/Daniel_2018-02-12.sql
DROP TABLE IF EXISTS `test`;
CREATE TABLE `test` (
`id` int(4) NOT NULL AUTO_INCREMENT,
`name` char(20) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=10 DEFAULT CHARSET=utf8;
LOCK TABLES `test` WRITE;
INSERT INTO `test` VALUES (1,'zhaoyue'),(2,'jesse'),(3,'jeacen'),(4,'elain'),(5,'wodi'),(6,'yingsui'),(7,'zhangyang'),(8,'zaixiangpan'),(9,'呵呵');
UNLOCK TABLES; #查看一下备份内容
#现在我们登进去删掉Daniel库
#然后再次创建Daniel库
[root@localhost /]# mysql -usystem -p123 Daniel </backup/Daniel_2018-02-12.sql #恢复 #压缩备份
[root@localhost /]# mysqldump -usystem -p123 -B Daniel|gzip >/backup/Daniel_$(date +%F).sql.gz #指定字符集备份
[root@localhost /]# mysqldump -usystem -p123 -B --default-character-set=utf8 Daniel|gzip >/backup/Daniel_$(date +%F)_utf8.sql.gz #备份多个数据库
#先创建三个数据库test1,test2,test3
[root@localhost /]# mysqldump -usystem -p123 --default-character-set=utf8 -B test1 test2 test3|gzip >/backup/Daniel_$(date +%F)_utf8.sql.gz
#这是放在了一个文件里,如何做分库备份呢?
#思路:写个脚本,去查数据库的所有库,然后写到列表里,逐条备份 #备份多个表
命令:mysqldump -u用户名 -p 数据库名 表名1 表名2 > 备份的文件名
[root@localhost /]# mysqldump -usystem -p Daniel test>/backup/test_table_$(date +%F).sql #Daniel是库后面跟表就OK,不要加B
[root@localhost /]# egrep -v "^--|\*|^$" /backup/test_table_2018-02-13.sql #查看一下,这是备份单个,接下来是辈分多个,我们先在Daniel库中创建几个表
mysql> create table t1(id int);
Query OK, 0 rows affected (0.08 sec) mysql> create table t2(id int);
Query OK, 0 rows affected (0.00 sec) mysql> create table t3(id int);
Query OK, 0 rows affected (0.06 sec) [root@localhost /]# mysqldump -usystem -p Daniel test t1 t2 t3>/backup/test_table_$(date +%F).sql #备份多个
[root@localhost /]# egrep -v "^--|\*|^$" /backup/test_table_2018-02-13.sql #如何进行分表备份
单表备份多写几次啊 #备份数据库结构
用-d就行
[root@localhost /]# mysqldump -usystem -p -d Daniel>/backup/Daniel_$(date +%F).sql
[root@localhost /]# mysqldump -usystem -p -d Daniel test>/backup/test_table_$(date +%F).sql #备份表结构 #前面用egrep的时候过滤很多,因为备份文件里的垃圾信息太多了,我们可以加参数解决
--comacpt #使输出内容更加简洁,不包括默认选项中各种注释,有如下几个参数的功能
--skip-add-drop-table --no-set-names --skip-disable-key --skip-locks #其他参数
-x 锁表 #备份的时候禁止写入数据,否则会乱掉,可以读
-l 锁表 #不允许读
MySQL恢复实战
#source恢复,登录到mysql界面,使用source 加备份数据库名字(要在这个备份数据库文件的当前路径进入mysql,也就是通过相对路径恢复),在这里恢复也可以指定恢复的字符集-- set names utf8; #mysql恢复,去掉dump直接使用mysql也可恶意恢复
MySQL非交互式操作数据库
#通过-e命令实现非交互式对话
[root@localhost ~]# mysql -usystem -p123 -e 'use Daniel;select * from test;'
#通过-e参数我可以在命令直接查看Daniel数据库的test表的所有东西,而且还可以过滤
[root@localhost ~]# mysql -usystem -p123 -e 'use Daniel;select * from test;'|grep zhao
[root@localhost ~]# mysql -usystem -p123 -e 'show processlist;' #查看进程数
[root@localhost ~]# mysql -usystem -p123 -e 'show full processlist; #显示的sql语句更全
[root@localhost ~]# mysql -usystem -p123 -e 'show variables;' #查看变量
[root@localhost ~]# mysql -usystem -p123 -e 'show global status;' #查看状态
[root@localhost ~]# mysql -usystem -p123 -e 'show global status;'|egrep "Com_select|Com_insert|Com_delete|Com_update"
Com_delete 0 #删除操作0条
Com_delete_multi 0
Com_insert 0
Com_insert_select 0
Com_select 127
Com_update 0
Com_update_multi 0 [root@localhost ~]# mysql -usystem -p123 -e "set global key_buffer_size = 32777218;" #修改全局参数,但重启不会生效 #其他非交互方法 1.echo
[root@localhost ~]# echo "show databases;" | mysql -usystem -p123 2.cat
[root@localhost ~]# cat |mysql -usystem -p123 <<EOF
> show databases;
> EOF
Mysql进阶-day2的更多相关文章
- mysql进阶(二十九)常用函数
mysql进阶(二十九)常用函数 一.数学函数 ABS(x) 返回x的绝对值 BIN(x) 返回x的二进制(OCT返回八进制,HEX返回十六进制) CEILING(x) 返回大于x的最小整数值 EXP ...
- mysql进阶(二十八)MySQL GRANT REVOKE用法
mysql进阶(二十八)MySQL GRANT REVOKE用法 MySQL的权限系统围绕着两个概念: 认证->确定用户是否允许连接数据库服务器: 授权->确定用户是否拥有足够的权限执 ...
- mysql进阶(二十七)数据库索引原理
mysql进阶(二十七)数据库索引原理 前言 本文主要是阐述MySQL索引机制,主要是说明存储引擎Innodb. 第一部分主要从数据结构及算法理论层面讨论MySQL数据库索引的数理基础. ...
- mysql进阶(二十六)MySQL 索引类型(初学者必看)
mysql进阶(二十六)MySQL 索引类型(初学者必看) 索引是快速搜索的关键.MySQL 索引的建立对于 MySQL 的高效运行是很重要的.下面介绍几种常见的 MySQL 索引类型. 在数 ...
- mysql进阶(十六)常见问题汇总
mysql进阶(十六)常见问题汇总 MySQL视图学习: http://www.itokit.com/2011/0908/67848.html 执行删除操作时,出现如下错误提示: 出现以上问题的原因是 ...
- 【转】MySQL— 进阶
[转]MySQL— 进阶 目录 一.视图 二.触发器 三.函数 四.存储过程 五.事务 一.视图 视图是一个虚拟表(非真实存在),其本质是[根据SQL语句获取动态的数据集,并为其命名],用户使用时只需 ...
- MySQL进阶(视图)---py全栈
目录 mysql进阶(视图)---py全栈 一.什么是视图? 二.视图的特性 三.视图的优点 四.使用场合 五.视图基本操作 六.案例 mysql进阶(视图)---py全栈 一.什么是视图? 视图是从 ...
- mysql进阶练习
一 . MySQL进阶练习 /*==========================创建班级表=============================*/ CREATE TABLE class ( ...
- MySQL进阶19--函数的创建(举例)/设置mysql的创建函数的权限/查看(show)/删除(drop) / 举4个栗子
/*MySQL进阶19 函数 存储过程和函数:都类似于java中的方法; 存储过程和函数通用好处: 1.提高代码的重用性 2.简化操作 好处: 减少操作次数,减少了编译次数,减少了和服务器的连接次数, ...
随机推荐
- ../../build/debug/codegen/libCodeGen.a(llvm-codegen.cc.o ):( data.rel.ro_ZTIN4llvm18ValueMapCallbackVHIPKNS_5ValueENS_6WeakVHENS_14ValueMapConfigIS3_EEEE[_ZTIN4llvm18ValueMapCallbackVHIPKNS_5ValueENS_
解决方式如下: wget http://llvm.org/releases/3.3/llvm-3.3.src.tar.gz tar xvzf llvm-3.2.src.tar.gz cd ...
- Google Java 编程风格指南 —— 见微知著
目录 前言 源文件基础 源文件结构 格式 命名约定 编程实践 Javadoc 后记 前言 这份文档是Google Java编程风格规范的完整定义.当且仅当一个Java源文件符合此文档中的规则, 我们才 ...
- redis中save和bgsave区别
转自:redis中save和bgsave区别 SAVE 和 BGSAVE 两个命令都会调用 rdbSave 函数,但它们调用的方式各有不同: SAVE 直接调用 rdbSave ,阻塞 Redis 主 ...
- 第十四章、Linux 账号管理与 ACL 权限配置
1. Linux 的账号与群组 1.1 使用者标识符: UID 与 GID 1.2 使用者账号:/etc/passwd 文件结构, /etc/shadow 文件结构 1.3 关于群组: /etc/gr ...
- 学习Rails之activeAdmin
一.开始ActiveAdmin Active Admin是一个发布在RAILS3中使用的Gem. 1.我们为了快速开始我们对Active Admin的了解,我们首先安装它: 在你GemFile ...
- android子线程更新UI
参考:https://www.cnblogs.com/joy99/p/6121280.html 子线程是不能直接更新UI的.Android实现View更新有两组方法,分别是invalidate和pos ...
- Package.json中dependencies依赖包中^符号和~符号前缀的区别
刚git了webpack的包发现package.json里面dependencies依赖包的版本号前面的符号有两种,一种是~,一种是^,如下图标记: 然后搜了下在stackoverflow上找到一个比 ...
- EF 查询数据不读取缓存的解决办法
EF查询(不使用缓存):Set<T>().AsNoTracking() 今天工作中发现一个很妖的问题,修改产品界面,修改数据后,数据库的值发生变化,感觉掉坑里了. 然后发现读取对象的方法是 ...
- DynamicJasper入门
JasperReport 在了解DynamicJasper之前不得不先了解一下jasperReport,jasperReport是基于Java的一个开源的报表工具,它使得你可以在Java环境下像其它的 ...
- 撩课-每天刷Web面试题(前10天汇总)-Day12
一.算法题部分 1. 如何获取浏览器URL中查询字符串中的参数 function getParamsWithUrl(url) { var args = url.split('?'); ] === ur ...