MySQL 服务基础、特点、编译安装、必要软件

2024-05-24 15:28

本文主要是介绍MySQL 服务基础、特点、编译安装、必要软件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

简介

特点

MySQL的常见用途包括:

版本

MySQL编译安装

yum安装MySQL

编译安装

安装必要软件包

ncuress-devel包

创建运行用户

解包

配置并编译安装

配置安装选项:

初始化数据库

权限设置

修改配置文件

 启动MySQL

 设置 root 密码


简介

mysql 是多线程,多用户的sql数据库服务,2008年之前,mysql项目由mysql AB公司进行开发、支持、发布,后来sun公司收购mysql AB公司,之后oracle公司又收购sun公司。目前mysql项目由oracle公司负责运营和维护。MySQL官网链接

特点

  1. 跨平台性:MySQL可以在多种操作系统上运行,包括Linux、Windows、macOS等。
  2. 客户端/服务器模型:MySQL使用客户端/服务器模型,客户端发送请求给服务器,服务器处理请求并返回结果。
  3. 多语言支持:MySQL支持多种编程语言,包括Python、Java、PHP、C++等。
  4. 可扩展性和灵活性:MySQL支持大量的存储引擎,如InnoDB、MyISAM等,可以根据需要选择合适的存储引擎。
  5. 数据安全:MySQL提供了多种安全特性,如用户权限管理、加密连接等,以确保数据安全。
  6. 高可用性和可伸缩性:MySQL支持主从复制、分区、集群等功能,可以实现高可用性和可伸缩性。

MySQL的常见用途包括:

  • 网站和应用数据库:作为后端数据库存储网站和应用数据。
  • 数据仓库:用于存储大量数据,支持复杂的查询和分析。
  • 日志记录:存储和分析日志数据,如用户行为、系统性能等。
  • 嵌入式系统:在嵌入式设备中作为本地数据库使用

版本

MySQL的版本分为社区版(MySQL Community Edition)和企业版(MySQL Enterprise Edition)。社区版是免费的,适合大多数用户;企业版则提供了额外的功能和商业支持。

MySQL编译安装

在安装之前最好测试是否安装、避免发生端口冲突、程序冲突等现象,建议先查询 MySQL 软件的安装情况,确认没有 使用以RPM方式安装的 mysql-server,mysql 软件包,否则建议将其卸载。

如果不确定是否安装可执行下面脚本代码

 下面脚本直接复制到命令行粘贴即可,不需要其他任何的操作。(sh执行方式。。。)

cat >> /check_install_mariadb.sh << csdnjingyu
#!/bin/bash
# 检查MySQL是否安装
if yum list installed | grep -q mysql-community-server; thenecho -e "\033[32mMySQL 已安装,正在尝试删除...\033[0m"sudo yum remove mysql-community-server -yecho -e "\033[32mMySQL 已删除。\033[0m"
elif yum list installed | grep -q mysql-server; thenecho -e "\033[32mMySQL 已安装,正在尝试删除...\033[0m"sudo yum remove mysql-server -yecho -e "\033[32mMySQL 已删除。\033[0m"
elseecho -e "\033[32mMySQL 没有安装。\033[0m"
fi
# 检查MariaDB是否安装
if yum list installed | grep -q mariadb-server; thenecho -e "\033[32mMariaDB 已安装,正在尝试删除...\033[0m"sudo yum remove mariadb-server -yecho -e "\033[32mMariaDB 已删除。\033[0m"
elseecho -e "\033[32mMariaDB 没有安装。\033[0m"
fi
# 提示完成
echo -e "\033[32m检查和删除过程已完成。\033[0m"
csdnjingyu
sh /check_install_mariadb.sh
rm -rf /check_install_mariadb.shclear

 上面脚本直接复制到命令行粘贴即可,不需要其他任何的操作。(sh执行方式。。。)

yum安装MySQL

yum install -y mariadb

编译安装

安装必要软件包

在安装 MySQL 的过程中,需要安装一些必要的软件包,包括cmake、gcc、g++、ncurses-devel、bison、openssl-devel等。可以使用以下命令安装:

yum -y install cmake gcc gcc-c++ ncurses-devel bison openssl-devel

MySQL5.X系列版本使用最为广泛,安装MySQL5.X需要cmake编译安装

ncuress-devel包

ncurses-devel 是一个软件开发包,它包含了 ncurses 库的头文件和链接库,供开发人员使用。ncurses 是一个提供终端处理功能的库,它允许程序在文本模式下提供更高级的输入/输出控制,比如窗口、彩色文本、鼠标支持等。在 Linux 系统中,如果你想要编译或安装某些需要 ncurses 库的程序,你需要安装 ncurses-devel 包。包是在 Red Hat 的系统盘里(如 CentOS、Fedora)自带的。

ncuress-devel包含了一下内容:

  • 头文件(.h 文件):这些文件包含了 ncurses 函数和宏的定义,供开发者在编写代码时使用。
  • 链接库(如 libncurses.so):这些是预编译的 ncurses 库文件,程序在编译和运行时需要链接这些库。

如果不安装可能会出现一下错误:

error: curses.h: No such file or directory(这意味着编译器找不到 ncurses 的头文件。通过安装 ncurses-devel 包,你可以解决这个问题。)

创建运行用户

groupadd mysql
useradd -M-s /sbin/nologin mysql -g  mysql

解包

tar xf mysql-5.6.36.tar.gz -C /usr/src && cd /usr/src/mysql-5.6.36/
tar xf mysql-5.6.36.tar.gz -C /usr/src
cd /usr/src/mysql-5.6.36/

配置并编译安装

(注意:编译安装时间一般较长。)

cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DENABLED_LOCAL_INFILE=1 -DDEFAULT_CHARSET=utf8mb4 -DDEFAULT_COLLATION=utf8mb4_general_ci
make && make install

配置安装选项:

-DCMAKE_NSTALL_PREFIX:

指定安装mysql数据可程序安装到的目录位置,如在/usr/local/mysql/目录下。

-DSYSCONFDIR:

指定初始化参数文件目录。

-DDEFAULT_CHARSET:

指定默认使用的字符集编码,如 utf-8。

(建议使用utf-8字符集编码。)

-DDEFAULT_COLLATION:

指定默认使用的字符集校对规则, utf8_general_ci 是适用于 utf-8

字符集的通用规则。

-DWITHLEXTRA_CHARSETS:

指定额外支持的其他字符集编码。

初始化数据库

编译完成后,在 MySQL 目录下找到 scripts 目录,执行以下命令初始化数据库:

cd /usr/local/mysql/scripts
./mysql_install_db --user=mysql --datadir=/usr/local/mysql/data/

初始化用于为mysql,位置到/usr/local/mysql/data 。

权限设置

chown -R mysql:mysql /usr/local/mysql

修改配置文件

进入 /usr/local/mysql 目录,将 my.cnf 文件复制一份,并将其命名为 mysql.cnf。然后修改 mysql.cnf 中的以下几个参数:

cp /etc/my.cnf /etc/mysql.cnf
[client]
socket=/usr/local/mysql/mysql.sock[mysqld]
port = 3306
socket=/usr/local/mysql/mysql.sock
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
pid-file = /usr/local/mysql/data/mysql.pid
log_error = /usr/local/mysql/data/mysql.err

 启动MySQL

/usr/local/mysql/bin/mysqld_safe --defaults-file=/usr/local/mysql/mysql.cnf &

 设置 root 密码

/usr/local/mysql/bin/mysqladmin -u root password 'new-password'

'new-password'是设置的密码 

这篇关于MySQL 服务基础、特点、编译安装、必要软件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/998794

相关文章

MySQL 中的 JSON 查询案例详解

《MySQL中的JSON查询案例详解》:本文主要介绍MySQL的JSON查询的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 的 jsON 路径格式基本结构路径组件详解特殊语法元素实际示例简单路径复杂路径简写操作符注意MySQL 的 J

SpringBoot基于配置实现短信服务策略的动态切换

《SpringBoot基于配置实现短信服务策略的动态切换》这篇文章主要为大家详细介绍了SpringBoot在接入多个短信服务商(如阿里云、腾讯云、华为云)后,如何根据配置或环境切换使用不同的服务商,需... 目录目标功能示例配置(application.yml)配置类绑定短信发送策略接口示例:阿里云 & 腾

Windows 上如果忘记了 MySQL 密码 重置密码的两种方法

《Windows上如果忘记了MySQL密码重置密码的两种方法》:本文主要介绍Windows上如果忘记了MySQL密码重置密码的两种方法,本文通过两种方法结合实例代码给大家介绍的非常详细,感... 目录方法 1:以跳过权限验证模式启动 mysql 并重置密码方法 2:使用 my.ini 文件的临时配置在 Wi

MySQL重复数据处理的七种高效方法

《MySQL重复数据处理的七种高效方法》你是不是也曾遇到过这样的烦恼:明明系统测试时一切正常,上线后却频频出现重复数据,大批量导数据时,总有那么几条不听话的记录导致整个事务莫名回滚,今天,我就跟大家分... 目录1. 重复数据插入问题分析1.1 问题本质1.2 常见场景图2. 基础解决方案:使用异常捕获3.

最详细安装 PostgreSQL方法及常见问题解决

《最详细安装PostgreSQL方法及常见问题解决》:本文主要介绍最详细安装PostgreSQL方法及常见问题解决,介绍了在Windows系统上安装PostgreSQL及Linux系统上安装Po... 目录一、在 Windows 系统上安装 PostgreSQL1. 下载 PostgreSQL 安装包2.

SQL中redo log 刷⼊磁盘的常见方法

《SQL中redolog刷⼊磁盘的常见方法》本文主要介绍了SQL中redolog刷⼊磁盘的常见方法,将redolog刷入磁盘的方法确保了数据的持久性和一致性,下面就来具体介绍一下,感兴趣的可以了解... 目录Redo Log 刷入磁盘的方法Redo Log 刷入磁盘的过程代码示例(伪代码)在数据库系统中,r

mysql中的group by高级用法

《mysql中的groupby高级用法》MySQL中的GROUPBY是数据聚合分析的核心功能,主要用于将结果集按指定列分组,并结合聚合函数进行统计计算,下面给大家介绍mysql中的groupby用法... 目录一、基本语法与核心功能二、基础用法示例1. 单列分组统计2. 多列组合分组3. 与WHERE结合使

Maven如何手动安装依赖到本地仓库

《Maven如何手动安装依赖到本地仓库》:本文主要介绍Maven如何手动安装依赖到本地仓库问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、下载依赖二、安装 JAR 文件到本地仓库三、验证安装四、在项目中使用该依赖1、注意事项2、额外提示总结一、下载依赖登

Mysql用户授权(GRANT)语法及示例解读

《Mysql用户授权(GRANT)语法及示例解读》:本文主要介绍Mysql用户授权(GRANT)语法及示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql用户授权(GRANT)语法授予用户权限语法GRANT语句中的<权限类型>的使用WITH GRANT

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1