mysql日常运维

一、Linux内核和发行版本

uname -a
 cat /etc/issue
 
 二、glibc的版本
   /lib/libc.so.6    ---没有man函数据的动态链接库
   
三、MySQL的版本
   MySQL二进制分发版的文件名格式为:mysql-VERSION-OS.tar.gz
   例如:Linux-Generic(glibc 2.5) (x86,64bit),Compressed TAR Archive(mysql-5.6.16-linux-glibc2.5-x86_64.tar.gz)
 
  1、下载
 http://dev.mysql.com/downloads/mysql/
 2、查rpm包装在什么目录下
   rpm -qpl MySQL-server-5.6.23-1.el6.i686.rpm  |more
   rpm -qpl MySQL-client-5.6.23-1.el6.x86_64.rpm |more
 3、更改rpm安装路径
  rpm --help
  rpm --prefix  --relocate
  rpmbuild spec binary rpm
  yum install 
   
 
四、rpm安装
rpm -ivh xxx.rmp
rpm -pql xxx.rmp

MySQL  实例安装和启动
1. 安装
mysql_install_db --defaults-file=/root/data/mysql3306/my.cnf --basedir=/usr/ --datadir=/root/data/mysql3306/data
2. 启动
mysqld_safe --defaults-file=/root/data/mysql3306/my.cnf &
3. 登录
mysql -h127.0.0.1 -uroot -P3306 -p

五、安装演示:
 
1.关闭mysql
   ps -ef |grep mysqld
   kill  3397 3801
   
2.安装
cat init3306
sh init3306.sh

3.启动
cat start3306.sh
sh start3306.sh
   
  注意:mysql_install_db(通过安装rpm包产生mysql_install_db),有如下命令查看:
   rpm -pql MySQL-server-5.5.42-1.linux2.6.i386.rpm |grep install
   which  mysql_install_db

4.看日志
tail  -100f /root/data/mysql3306/log/alert.log
  发生数据字典不存在,就会自动创建。。。。

5.查看进程
ps -ef |grep mysqld
    mysqld_safe是mysqld的父进程

6.登录
sh  my3306.sh  --mysql -h127.0.0.1 -uroot --P3306

六、脚本:
  1.---安装mysql: init3306.sh     
  rm -rf /root/data/mysql3306/data/*
  rm -rf /root/log/mysql3306/iblog/*
  rm -rf /root/log/mysql3306/binlog/*
  chmod -R 777 /root/data/mysql3306/data/
  chmod -R 777 /root/log/mysql3306/iblog/
  chmod -R 777 /root/log/mysql3306/binlog/
  
  chmod 755 /root/data/mysql3306/my.cnf
  
  mysql_install_db --defaults-file=/root/data/mysql3306/my.cnf --basedir=/usr/ --datadir=/root/data/mysql3306/data
  
  chmod -R 777 /root/data/mysql/3306/data/
  chmod -R 777 /root/log/mysql3306/iblog/
  chmod -R 777 /root/log/mysql3306/binlog/

2.--启动mysql: start336.sh    
  mysqld_safe --defaults-file=/root/data/mysql3306/my.cnf &
  
  
  3.--登录mysql: my3306.sh       
  mysql -h127.0.0.1 -uroot -P3306 -p

------研究下
cd /root/data/mysql3306/data/mysql    
cd /root/data/mysql3306/data/performance_schema  --性能相关的
cd /root/data/mysql3306/data/test    ---测试库
cd /root/log/mysql3306/iblog/        ---innodb自己的数据和日志

------了解my.cnf(多实例用端口来取分)
vi /root/data/mysql3306/my.cnf

[client]
port=3306
socket=/root/data/mysql3306/run/mysql.sock

[mysql]
port=3306
promprt=\\[email protected]\\d \\r:\\m:\\s>

[mysqld]
default-storage-engine=INNODB
character-set-server=iatin1
explicit_defaults_for_timestamp=true

#dir
innodb_log_group_home_dir=/root/log/mysql3306/iblog
innodb_data_home_dir=/root/log/mysql3306/iblog
basedir=/usr
datadir=/root/data/mysql3306/data
tmpdir=/root/data/mysql3306/tmp
slave_load_tmpdir=/root/data/mysql3306/tmp
log-error=/root/data/mysql3306/log/alert.log
slow_query_log_file=/root/data/mysql3306/log/slow.log
relay_log_info_file=/root/log/mysql3306/binlog/relay-log.info
master-info-file=/root/log/mysql3306/binlog/master.info
socket=/root/data/mysql3306/run/mysql.sock
log-bin=/root/log/mysql3306/binlog/binlog
relay-log=/root/log/mysql3306/binlog/relaylog

innodb_force_recovery=0

七、操作mysql

1、登录mysql:
  本地:  mysql -u$usrename -p$password
  远程:  mysql -u$username -p$passwrod -h$ip
  多实例:mysql -u$username -p$passwrod -P$port
  
2、用户操用
(1)创建用户
  方法一:
   insert into mysql.user(user,host,password) values(‘mytest‘,‘localhost‘,password(‘1234‘));
   flush privilege;
  方法二:create user [email protected]‘%‘ identified by ‘1234‘;
    
(2)用户授权
 单纯的授权
   grant all privileges on *.* to [email protected]; 
   grant insert,update,delete,select on *.* to [email protected];
 授权并创建用户  
   grant all privileges on *.* to [email protected] identified by ‘1234‘;--创建用户并刷缓存,
                                                                     (等同于:insert into mysql.user ,flush privilege)
   grant all privileges on *.* to [email protected];   --对象权限
   grant super on *.* to [email protected]‘%‘;   --系统权限  (supert相当于oracle中的dba权限)
   
  
  
3、实操
show databases;   --查看所有的数据库
use mysql;        --切到mysql数据库
use tables;       --在mysql库的tables
select user,host,password from mysql.user;  ----查mysql的所有用户,这个是由mysql_install_db创建的
grant all privilege on *.* to [email protected]‘%‘; --all代表(select update,delete,alter admin,super_acl),第一个*用户,第二个*对象,%所有的主机 
mysql -h127.0.0.1 -utest_1    ----用grant创建的用户登录mysql
select user();   ---当前是什么用户
create database jianfeng; ---创建数据库(mysql中的数据库类似于oracle中的schema
create table user(id int) engine=innodb   ---创建表;
grant select on jianfeng.user to [email protected]‘%‘;  ---jianfeng.user表的查询授权给test_1用户
insert into mysql.user(user,host,password) values(‘test_2‘,‘%‘,password(‘1234‘)); --用这种方法创建test_2用户,有个问题权限没有
flush privileges;  ---把mysql.user表的用户权限重新刷到内存中
show master status\G; 
change master to xxx; 
show processlist;   ---查看当前用户的连接,线程形式(类似oracle中的v$session)

4、drop table处理
 rename table test_1 to test;(可以快速切回来rename table test to test_1;)
 备份mysqldump:mysqldump -h127.0.0.1 -uroot mydb gyj_t1 >/tmp/gyj_t1.sql
 drop table test;

5、自增主键(最好是自己定义主键,系统默认的是全局的增量)
create table test (id int primary key auto_increment,name varchar(100)) engine=innodb;
show create table test\G;
create index test_name_idx on test(name);
show create table test\G;
insert into test(name) values(‘test‘);
commit;
select * from test;

6、alter table处理  --会动原来的数据,需要拷贝数据
alter table test add coll int;

7、执行计划
select * from test where id=1\G;
explain select * from test where id=1;
create index test_id_coll_idx on test(id,coll);
explain select * from test where id=1;
create index test_col_name on test(coll,name);
explain select * from test where coll>10 and name=‘xx‘;
show create table test\G;
alter table test drop index test_name_idx;
explain select * from test where coll>10 and name>‘xx‘;

8、数据导出
(1)用dump导出数据
mysqldump -h127.0.0.1 -uroot mydb gyj_t1 >/tmp/xx.sql
drop table test;
source /tmp/xx.sql    --导入数据

(2)用select导出数据
select * from test into outfile ‘/tmp/yy.sql‘;

9、数据迁移
(1)停机方式
   mysqldump/loadata
(2)不停机方式
  物理上:搭备库(可以级联5.5-->5.6,向下兼容的)
     把主库read only,备库就能把主库转过来的binlog消化完,再把备库切为主
     show variables like ‘%read%‘;
     set global read_only=on;
     insert into test(name) values(‘xx‘);  --插不进的,不能用root用户
(3)不同平台小表:oracle--->mysql
      脚本:synfull.pl
      
(4)不同平台的一个大表迁多:增量迁移
    a.把数据的全量迁过去
    b.把迁的过程中产生的日志传过去
    c.apply增量
    d.锁表切切换
 
 (5)增量
  a.Oracle:物化视图
  b.MySQL:trigger
     create trigger tri_test
     before insert,delete,update
     insert test_log value(type,id);
     end;
     /
   insert into test values(1,‘xxx‘);
   test_log value(‘insert‘,‘1‘);  
   lock table test;
   应用切换
   
10、binlog
   reset master;   --会把当前的binlog清掉
   show binlog events;
   create table x1(id int);
   show binlog events;
   insert into x1 values(1);
   commit;
   show binlog events;
  类似于: mysqlbinlog -vvv binlog.00001 > /tmp/binlog.log
           vi /tmp/binlog.log
   WAL: write ahead log,日志优先写

11、归档   
  flush logs;
  show master status;
  
 
 write ahead log. recover backup, duriably. undo acid mvcc
 
12、参数和统计信息
show variables;  ----参数
show variables like ‘%bin%‘;
show status;      ----统计信息
show global status like‘%insert%‘;
insert into test(name) values(‘xxxxx‘);

show variables like ‘%default%‘;
set global default_storage_engine=myisam;   ---不影响当前会话的操作,影响新建立的连接
set session default_storage_engine=myisam;  ---影响当前会话的操作

---连接池
max_connect
min_connect
max_idle
time_out

disconnect --释放

时间: 2024-09-27 19:54:57

mysql日常运维的相关文章

mysql日常运维与参数调优

日常运维 DBA运维工作 日常 导数据,数据修改,表结构变更 加权限,问题处理 其它 数据库选型部署,设计,监控,备份,优化等 日常运维工作: 导数据及注意事项 数据修改及注意事项 表结构变更及注意事项 加权限及注意事项 问题处理,如数据库响应慢 导数据及注意事项 数据最终形式(csv,sql文本,还是直接导入某库中) 导数据方法(mysqldump,select into outfile,) 注意事项 导出为csv格式需要file权限,并且只能数据库本地导 避免锁库锁表(mysqldump使用

MySQL 日常运维业务账号权限的控制

在MySQL数据库日常运维中,对业务子账号的权限的统一控制十分必要. 业务上基本分为读账号和写账号两种账号,所以可以整理为固定的存储过程,让数据库自动生成对应的库的账号,随机密码.以及统一的读权限,写权限.(这里没有对 host进行过多的限制.只赋给通用的192.168.% .有兴趣的同学可以在存储过程加个参数,对host 控制) delimiter // set session sql_log_bin=OFF; drop PROCEDURE IF EXISTS `usercrt` // CRE

MySQL日常运维操作---持续更新

1.查看当前连接数: 这些参数都是什么意思呢? Threads_cached 25 ##mysql管理的线程池中还有多少可以被复用的资源 Threads_connected 9 ##打开的连接数 Threads_created 55158 ##表示创建过的线程数,如果发现Threads_created值过大的话,表明MySQL服务器一直在创建线程,这也是比较耗资源,可以适当增加配置文件中thread_cache_size值,查询服务器 Threads_running 1 ##激活的连接数,这个数

日常运维工作中如何确保你的linux操作系统安全

在现在这个世道中,Linux操作系统的安全是十分重要的.但是,你得知道怎么干.一个简单反恶意程序软件是远远不够的,你需要采取其它措施来协同工作.下面是日常运维工作中常用的几种Linux安全的策略方法. 1. 使用SELinux SELinux是用来对Linux进行安全加固的,有了它,用户和管理员们就可以对访问控制进行更多控制.SELinux为访问控制添加了更细的颗粒度控制.与仅可以指定谁可以读.写或执行一个文件的权限不同的是,SELinux可以让你指定谁可以删除链接.只能追加.移动一个文件之类的

zookeeper 用法和日常运维

本文以ZooKeeper3.4.3版本的官方指南为基础:http://zookeeper.apache.org/doc/r3.4.3/zookeeperAdmin.html,补充一些作者运维实践中的要点,围绕ZK的部署和运维两个方面讲一些管理员需要知道的东西.本文并非一个ZK搭建的快速入门,关于这方面,可以查看<ZooKeeper快速搭建>. 1.部署 本章节主要讲述如何部署ZooKeeper,包括以下三部分的内容: 系统环境 集群模式的配置 单机模式的配置 系统环境和集群模式配置这两节内容大

Hbase 日常运维

1.1监控Hbase运行状况 1.1.1操作系统 1.1.1.1IO a.群集网络IO,磁盘IO,HDFS IO IO越大说明文件读写操作越多.当IO突然增加时,有可能:1.compact队列较大,集群正在进行大量压缩操作. 2.正在执行mapreduce作业 可以通过CDH前台查看整个集群综合的数据或进入指定机器的前台查看单台机器的数据: b.Io wait 磁盘IO对集群的影响比较大,如果io wait时间过长需检查系统或磁盘是否有异常.通常IO增加时io wait也会增加,现在FMS的机器

hadoop日常运维与升级总结

日常运维 升级 问题处理方法 日常运维 进程管理 由于配置文件的更改,需要重启生效, 或者是进程自己因某种致命原因终止, 或者发现进程工作出现异常等情况下,需要进行手动进程的关闭或启动, 或者是增删节点过程中的需要, 进程的关闭与启动,使用 hadoop-daemon.sh start|stop datanode/namenode/journalnode/zkfc yarn-daemon.sh start|stop nodemanager/resourcemanager 检查进程是否完成关闭:

MySQL数据库运维课程

MySQL数据库运维课程 http://www.dataguru.cn/article-4834-1.html?union_site=comm100 课程大纲 第一课:机器选型.系统规划 第二课:安装部署 第三课:压力测试 第四课:性能优化 第五课:字符集和权限安全 第六课:日志系统 第七课:备份与恢复1 第八课:备份与恢复2 第九课:常用工具 第十课:MySQL集群 第十一课:分布式集群 第十二课:集群高可用(HA)和容灾演练 第十三课:自动化运维 第十四课:监控和审计系统 第十五课:成长规划

Openstack云计算项目实施其二(安装后日常运维)

5 安装后日常运维   运维基本的操作都在控制节点上的,较为方便的方式就是在openstack 的 dashboard(仪表盘)中进行,进入 dashboard 的方式就是直接在浏览器中输入控制节点的 IP 地址.(需要注意的是浏览器选择方面最好选择火狐浏览器或则谷歌浏览器,因为相对于 IE 浏览器而言,前面两个浏览器对于 openstack 的支持性要好,使用 IE 会在打开实例控制台时无法进入,出现"No vnc...."的错误信息) 用户名和密码放在控制节点/root 下,存放在