MySQL -2- 体系结构--随笔小记
简介与安装
NoSQL
RDBMS
版本
安装方式
二进制安装,源码安装
体系结构
CS模型
TCP/IP
socket
mysql master thread
实例
mysqld 的程序构成
连接层 协议、验证、链接线程
SQL层 语法语义、权限、解析、优化、执行、日志记录
存储引擎层:存取磁盘数据
逻辑结构:库、表、属性、字符集和校对规则
表:表明、字段、记录、元数据
物理存储结构
库:就是一个目录
表:myisam、frm、myd、myi
innodb :frm ibd
innodb 存储引擎表
段 区 页
MySQL基础管理
用户权限
create user oldboy@'10.0.0.%' identified by '';
drop user oldboy@'10.0.0.%' ';
alter user oldboy@'10.0.0.%' identified by '123
select user,host from mysql.user; grant all on *.* to root@'10.0.0.%';
revoke drop,delete,insert,update from root@'10.0.0.%';
show grants for root@'10.0.0.%';
参数--root忘记密码时使用socket方式登录修改
--skip-grant-tables
--skip-networking mysql -uroot -p -S /tmp/mysql.sock --socket链接方式
mysql -uroot -p -h192.168.16.174 -P3306 --tcp/IP链接方式
-P必须与-h 同时使用
-e 参数:免交互方式使用数据库,如:
mysql -uroot -p123 -e"select user,host fom mysql.user;"
< 导入脚本数据
mysql -uroot -p <word.sql;
启动方式
service mysqld start --> ./mysql.server start -->mysqld_safe
./bin/mysqld_safe & --> mysqld_safe --> mysqld
systemd :systemctl start mysqld
mysql --skip-grant-tables --skip-networking
初始化配置:预编译、配置文件、命令行
作用:控制MySQL的启动、
配置文件:/etc/my.conf
命令行:仅限于mysqld_safe 和mysqld,临时维护使用
初始化配置文件:
初始化配置文件顺序,有重复的以最后一个为准
mysqld --help --verbose|grep my.cnf
但指定的除外:
--default-file=/etc/my.cnf
my.cnf
[mysqld]
user=mysql
basedir=/u02/app/mysql
datadir=/u02/data/mysql
server_id=6
port=3306
socket=/tmp/mysql.sock [mysql]
socket=/tmp/mysql.sock
prompt=3306[\\d]> #[mysqld_safe]
#log-error=/var/log/mysqld.log
#pid-file=/var/run/mysqld/mysqld.pid
标签类型:客户端、服务端
服务端标签:
【mysqld】
【mysql_safe】
【server】
客户端标签:
【mysql】
【mysqldump】
【client】
服务端例子:
【mysqld】
user=mysql
basedir=/u02/app/mysql
datadir=/u02/data/mysql
socket=/tmp/mysql.sock
server_id=6 ----5.7版本必须字段,范围1-65535
port=3306
log_err=/u02/mysql/data/mysql/mysql..log
说明:socket=/tmp/mysql.sock可以任意指定如:socket=/etc/mysql.sockaaa
重启数据库后,再次登录时需要指定
mysql -uroot -p -S socket=/etc/mysql.sockaaa service mysqld stop
mysql -uroot -p
Enter password:
ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
报错原因:数据库没起,或者指定socket文件错误
netstat -lnp|grep 3306
system start mysqld
客户端例子:
【mysql】
socket=/tmp/mysql.sock
prompt=3306[\\d]>
#user=root
#passwd=123 说明:prompt=3306[\\d]> 用于显示登录后的路径
如此时显示 3306[(none)]>
修改prompt=[\\d]>
此时显示 [(none)]>
修改 prompt=mysql>
此时显示 mysql>
多实例应用
1、准备多个目录
mkdir -p /u02/data/330{7,8,9}/data
2、生成配置文件
cat >/u02/data/3307/my.cnf<<zfd
[mysqld]
basedir=/u02/app/mysql
datadir=/u02/data/3307/data
socket=/u02/data/3307/mysql.sock
port=3307
log_err=/u02/data/3307/mysql.log
serve_id=7
log_bin=/u02/data/3307/mysql-bin
zfd cat >/u02/data/3308/my.cnf<<zfd
[mysqld]
basedir=/u02/app/mysql
datadir=/u02/data/3308/data
socket=/u02/data/3308/mysql.sock
port=3308
log_err=/u02/data/3308/mysql.log
serve_id=8
log_bin=/u02/data/3308/mysql-bin
zfd cat >/u02/data/3309/my.cnf<<zfd
[mysqld]
basedir=/u02/app/mysql
datadir=/u02/data/3309/data
socket=/u02/data/3309/mysql.sock
port=3309
log_err=/u02/data/3309/mysql.log
serve_id=9
log_bin=/u02/data/3309/mysql-bin
zfd
3、初始化三套数据
mv /etc/my.cnf /etc/my.cnf.bak
mysqld --initialize-insecure --user=mysql --datadir=/u02/data/3307/data --basedir=/u02/app/mysql --pid-file=/u02/data/3307/data/zhangfd.pid
mysqld --initialize-insecure --user=mysql --datadir=/u02/data/3308/data --basedir=/u02/app/mysql
mysqld --initialize-insecure --user=mysql --datadir=/u02/data/3309/data --basedir=/u02/app/mysql
4、system管理多实例
cd /etc/systemd/system
cp mysqld.service mysqld3307.service
cp mysqld.service mysqld3308.service
cp mysqld.service mysqld3309.service
修改各个service :ExecStart=/u02/app/mysql/bin/mysqld --defaults-file=/u02/data/3307/my.cnf
使用service sshd start 方式启停服务的设置待解决,因为系统不能使用systemctl命令来管理服务*******
5、授权
chown -R mysql.mysql /u02/data/*
6、启动
systemctl start mysql3307.service
systemctl start mysql3308.service
systemctl start mysql3309.service
netstat -lnp|grep 330
MySQL -2- 体系结构--随笔小记的更多相关文章
- 【转】数据库介绍(MySQL安装 体系结构、基本管理)
[转]数据库介绍(MySQL安装 体系结构.基本管理) 第1章 数据库介绍及mysql安装 1.1 数据库简介 数据库,简而言之可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据运行新 ...
- 004:MySQL数据库体系结构
目录 一. MySQL数据库体系结构 1.MySQL数据库体系结构介绍 1 数据库定义 2 数据库实例 2. MySQL体系结构 1 单进程多线程结构 2 存储引擎的概念 3 体系结构图 4 逻辑存储 ...
- 温故知新-Mysql的体系结构概览&sql优化步骤
文章目录 Mysql的体系结构概览 连接层 服务层 引擎层 存储层 存储引擎 存储引擎概述 存储引擎特性
第1章 数据库介绍及mysql安装 1.1 数据库简介 数据库,简而言之可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据运行新增.截取.更新.删除等操作. 所谓“数据库”系以一定方式 ...
- mysql -> 简介&体系结构_01
数据库简介 数据库,简而言之可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据运行新增.截取.更新.删除等操作. 所谓“数据库”系以一定方式储存在一起.能予多个用户共享.具有尽可能小的 ...
- mysql 内存体系结构--session
体系结构tmp_table_size & max_heap_table_size ,这个是会话级的内存结构mysql使用总内存 = global_buffers + thread_buffer ...
- MySQL之体系结构与存储实例
定义数据库和实例 在数据库领域中有两个词很容易混淆,这就是“数据库”(database)和“实例”(instance).作为常见的数据库术语,这两个词的定义如下: 数据库:物理操作系统文件或其他形式文 ...
- [高性能MYSQL 读后随笔] 关于事务的隔离级别(一)
一.锁的种类 MySQL中锁的种类很多,有常见的表锁和行锁,也有新加入的Metadata Lock等等,表锁是对一整张表加锁,虽然可分为读锁和写锁,但毕竟是锁住整张表,会导致并发能力下降,一般是做dd ...
随机推荐
- zabbix-server一键部署
最近想写一个zabbix脚本,自己尝试几次,能够实现,但是太糙了,在github上发现一个很好,谢谢作者脚本作者:火星小刘 web:www.huoxingxiaoliu.com email:xtlyk ...
- HTML5+CSS3制作无限滚动与文字跳动效果
㈠用HTML5+CSS3做无限滚动效果 ⑴逻辑分析 ⑵实践示例 前5张图片为所有图片显示区,假设总长度为1100px: 后面出现的五张图片为克隆区,只是将前面的图片拷贝了一份: 然后将前五张和后五张的 ...
- luogu 5311 [Ynoi2011]D1T3 动态点分治+树状数组
我这份代码已经奇怪到一定程度了~ 洛谷上一直 $TLE$,但是本地造了几个数据都过了. 简单说一下题解: 先建出来点分树. 对于每一个询问,在点分树中尽可能向上跳祖先,看是否能够处理这个询问. 找到最 ...
- 在对 Angular 的文档 aio 进行编译的时候提示错误
error angular-examples-master@1.0.0: The engine "yarn" is incompatible with this module. E ...
- THUSC 2017 游记
Day0 早上在家里整理东西. 下午坐飞机去北京.(怎么又去北京,上周刚去的北京) 一开始飞机爬升的时候太无聊就睡着了.醒了以后就开始吃东西.吐槽一句:厦航的飞机就是好啊.上面的点心也比上次海航的好吃 ...
- 微信小程序_(组件)form表单
Form表单.switch开关.数值选择器效果 官方文档:传送门 点击提交表单(按钮,提交开关,数值选择器,输入文本中)的值,显示在控制台上,点击重置,重置表单中的值. 实现过程 form表单,添加f ...
- 分布式-信息方式-ActiveMQ的Destination高级特性1
ActiveMQ的Destination高级特性 Destination高级特性----->Composite Destinations 组合队列Composite Destinations : ...
- 高并发通信模型NIO
一.NIO和BIO的对比 BIO通信模型 2.配置 BIO tomcat server.xml NIO 3.NIO
- Spring理解?
(1)Spring是一个轻量级控制反转(IoC)和面向切面(AOP)的容器框架,是解决企业应用开发的复杂性,为J2EE应用提供了全方位的整合框架,在Spring框架下实现多个子框架的组合. (2)Sp ...
- C++如何限制对象在堆上或栈上生成
1,限制类的对象只能生成在栈上 将 operator new 各种原型设为私有 #include <iostream> class OnlyOnStack { public: OnlyOn ...