千家信息网

MySQL服务器企业实战一

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,1.MySQL数据库使用场景介绍目前Web主流架构是LAMP(Linux+Apache+Mysql+PHP)和LNMP(Linux+Nginx+Mysql+PHP), Mysql更是得到各位IT运维、
千家信息网最后更新 2025年01月20日MySQL服务器企业实战一

1.MySQL数据库使用场景介绍

目前Web主流架构是LAMP(Linux+Apache+Mysql+PHP)和LNMP(Linux+Nginx+Mysql+PHP), Mysql更是得到各位IT运维、DBA的青睐。

MySQL常用的两大引擎有MyISAM和InnoDB,那么它们之间的区别是什么,根据不同场合该如何进行选择。

MyISAM类型的数据库表强调的是性能,其执行速度比InnoDB类型更快,但不提供事务支持,不支持外键,如果执行大量的查询操作,MyISAM引擎是更好的选择。

InnoDB提供事务支持事务、外部键、行级锁等高级数据库功能,执行大量的insert或update操作,出于性能方面的考虑,可以使用InnoDB引擎。

2.MySQL数据库安装方式

1)CentOS7.X基于YUM方式安装MySQL的方法,执行命令如下:

#yum install mariadb-server mariadb mariadb-libs -y

2)源码安装MySQL 5.5.6方法

[root@localhost tools]# wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.62.tar.gz

[root@localhost tools]# tar -zxvf mysql-5.5.62.tar.gz

[root@localhost tools]# yum install cmake ncurses - devel ncurses -y

[root@localhost tools]# cd mysql-5.5.62

[root@localhost mysql-5.5.62]#

cmake \

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \

-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \

-DMYSQL_DATADIR=/data/mysql \ #数据库存放路径

-DSYSCONFDIR=/etc \ #配置文件路径

-DMYSQL_USER=mysql \ #运行用户

-DMYSQL_TCP_PORT=3306 \

-DWITH_XTRADB_STORAGE_ENGINE=1 \

-DWITH_MYISAM_STORAGE_ENGINE=1 \ #开启MyISAM引擎支持

-DWITH_INNOBASE_STORAGE_ENGINE=1 \ #开启InnoDB引擎支持

-DWITH_MEMORY_STORAGE_ENGINE=1 \

-DWITH_READLINE=1 \

-DENABLED_LOCAL_INFILE=1 \

-DWITH_PARTITION_STORAGE_ENGINE=1 \

-DWITH_EXTRA_CHARSETS=1 \

-DEXTRA_CHARSETS=all \ #安装扩展所有字符集

-DDEFAULT_CHARSET=utf8 \ #默认字符集

-DDEFAULT_COLLATION=utf8_general_ci \

-DWITH_BIG_TABLES=1 \

-DWITH_DEBUG=0

#cmake报以下错误

-- Could NOT find Curses (missing: CURSES_LIBRARY CURSES_INCLUDE_PATH)

CMake Error at cmake/readline.cmake:83 (MESSAGE):

Curses library not found. Please install appropriate package,

remove CMakeCache.txt and rerun cmake.On Debian/Ubuntu, package name is libncurses5-dev, on Redhat and derivates it is ncurses-devel.

Call Stack (most recent call first):

cmake/readline.cmake:118 (FIND_CURSES)

cmake/readline.cmake:214 (MYSQL_USE_BUNDLED_READLINE)

CMakeLists.txt:394 (MYSQL_CHECK_READLINE)

[root@localhost mysql-5.5.62]# rm CMakeCache.txt #此步骤非常重要

[root@localhost mysql-5.5.62]# yum install bison ncurses-devel git

#cmake #重新配置环境

[root@localhost mysql-5.5.62]# make && make install

[root@localhost mysql]# pwd

/usr/local/mysql

[root@localhost mysql]# \cp support-files/my-large.cnf /etc/my.cnf

[root@localhost mysql]# \cp support-files/mysql.server /etc/init.d/mysqld

[root@localhost mysql]# chkconfig --add mysqld

[root@localhost mysql]# chkconfig --level 35 mysqld on

[root@localhost mysql]# mkdir -p /data/mysql

[root@localhost mysql]# /usr/local/mysql/scripts/mysql_install_db --user=mysql --datadir=/data/mysql/ --basedir=/usr/local/mysql/ #初始化数据库

Installing MySQL system tables...

[root@localhost mysql]# ln -s /usr/local/mysql/bin/ * /usr/bin/

[root@localhost mysql]# service mysqld restart

ERROR! MySQL server PID file could not be found!

Starting MySQL.Logging to '/data/mysql/localhost.localdomain.err'.

. SUCCESS!

[root@localhost mysql]# mysql

Welcome to the MariaDB monitor. Commands end with ; or \g.

Your MySQL connection id is 1

Server version: 5.5.62-log Source distribution

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MySQL [(none)]>

MySQL [(none)]> use mysql;

Database changed

MySQL [mysql]> update user set password=password('****') where user='root'; #设置密码

Query OK, 4 rows affected (0.00 sec)

Rows matched: 4 Changed: 4 Warnings: 0

MySQL [mysql]> flush privileges;

3.MySQL数据库配置文件详解

[mysqld]

port = 3306

socket = /tmp/mysql.sock #通信设置

skip-external-locking

key_buffer_size = 256M #索引缓冲区的大小

max_allowed_packet = 1M

table_open_cache = 256 #打开表的缓存数量

sort_buffer_size = 1M

read_buffer_size = 1M #读查询操作所能使用的缓冲区大小

read_rnd_buffer_size = 4M

myisam_sort_buffer_size = 64M

thread_cache_size = 8 #可重用的线程数

query_cache_size= 16M #查询结果缓冲区大小

# Try number of CPU's*2 for thread_concurrency

thread_concurrency = 8 #最大线程数,服务器逻辑CPU*2

0