记录CentOS 7.4 上安装MySQL&MariaDB&Redis&Mongodb

原文:记录CentOS 7.4 上安装MySQL&MariaDB&Redis&Mongodb

记录CentOS 7.4 上安装MySQL&MariaDB&Redis&Mongodb

前段时间我个人Google服务器意外不能用,并且我犯了一件很低级的错误,直接在gcp讲服务器实例给释放掉,导致我的数据全部丢失,现在新搞一个服务器,顺便记录一下CentOS 7.4 MySQL&MariaDB&Redis&Mongodb 的安装

1祝大家:诸事顺利,2019 发大财!

本人将一如既往,更新我的博客,努力为博客园贡献文章!

Mysql 安装

随着CentOS 7 MySQL的发布,世界上最流行的开源关系数据库管理系统在CentOS的仓库中不再可用,MariaDB已经成为默认的数据库系统。 MariaDB是一个向后兼容的二进制嵌入式MySQL替代品

由于mysql在Linux的默认存储库中不可用,这里我们采用mysql yum 存储库安装mysql软件包

下载并添加存储库

sudo yum localinstall https://dev.mysql.com/get/mysql80-community-release-el7-1.noarch.rpm

安装MySQL 8.0包(这里我们直接安装mysql 8.0)

与其他使用yum的软件包一样安装MySQL,在安装过程中,yum可能会提示您导入MySQL GPG密钥。 键入y并按Enter键

yum install mysql-community-server

启动MySQL

安装完成后,启用并启动MySQL服务类型:

sudo systemctl enable mysqld

sudo systemctl start mysqld

我们可以通过键入以下命令来检查MySQL服务状态

sudo systemctl status mysqld

MySQL安全

当第一次启动MySQL服务器时,为MySQL根用户生成一个临时密码。 您可以通过运行以下命令找到密码:

sudo grep 'temporary password' /var/log/mysqld.log

输出应该看起来像这样:

2018-05-26T23:50:09.270656Z 5 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: HgPW+/Phb2Ql

记下密码 HgPW+/Phb2Ql,因为下一个命令会要求您输入临时的root密码。

运行mysql_secure_installation命令来提高MySQL安装的安全性:

sudo mysql_secure_installation

客户端连接

  1. 进入mysql

mysql -u 'name' -p 'xx'

  1. 选取mysql库,查看user表

select host, user, authentication_string, plugin from user;

这里host 是不允许远程连接的

  1. 授权 root 用户的所有权限并设置远程访问

在mysql8.0创建用户和授权和之前不太一样了,其实严格上来讲,也不能说是不一样,只能说是更严格,mysql8.0需要先创建用户和设置密码,然后才能授权
MySQL 安装完成后只支持 localhost 访问,我们必须设置一下才可以远程访问

3.1 先创建一个用户

create user 'guo_test'@'%' identified by '123123';

3.2 再进行授权

grant all privileges on . to 'guo_test'@'%' with grant option;

3.3 强调一点,如果还是用原来5.7的那种方式,会报错误

grant all privileges on . to 'root'@'%' identified by '123123';

3.4 授权 root 用户的所有权限并设置远程访问

GRANT ALL ON . TO 'root'@'%';

GRANT ALL ON 表示所有权限,% 表示通配所有 host,可以访问远程。

3.5 刷新权限

flush privileges;

3.6 补充

参考这里-stack over flowwer

mysql 官网-创建用户语法

mysql 官网-修改用户语法

如果这里我们远程依然连接不上,请修改用户授权规则

ALTER USER 'guo_test'@'%' IDENTIFIED WITH mysql_native_password BY 'password';

我们一般情况下,禁止root用户远程连接,所以我这里采取test账户授权远程连接

MySQL 安装完成

ok这里我们就成功安装上mysql,可以尝试用mysql client remote 链接一下。

MariaDb 安装

Redis 安装

redis 安装既可以采用yum install 方式安装,也可以采用源码方式安装,yum方式安装时,为了提高安装速度,可以切换redis镜像源。

这里我们采用源码方式安装

yum方式安装参考这里-Centos 7下使用yum安装redis

yum方式安装参考这里-Centos 7下使用yum安装redis

源码安装

安装Redis需要知道自己需要哪个版本,有针对性的安装,比如如果需要redis GEO这个地理集合的特性,那么redis版本就不能低于3.2版本,由于这个特性是3.2版本才有的。另外需要注意的是,Redis约定次版本号(即第一个小数点后的数字)为偶数的版本是稳定版(如2.8版、3.0版),奇数版本是非稳定版(如2.7版、2.9版),生产环境下一般需要使用稳定版本

下载redis 安装包

mkdir -p /home/redis
cd /home/redis
wget http://download.redis.io/releases/redis-4.0.2.tar.gz

编译

redis是通过源码安装的,所以我们需要先安装gcc编译器,同时安装redis所依赖的tcl包

yum install gcc tcl

解压安装包并安装


tar xzf redis-4.0.2.tar.gz/ tar -xzvf redis-4.0.2.tar.gz
cd redis-4.0.2
make
make install

Redis没有其他外部依赖,安装过程很简单。编译后在Redis源代码目录的src文件夹中可以找到若干个可执行程序,安装完后,在/usr/local/bin目录中可以找到刚刚安装的redis可执行文件

启动和停止Redis

启动Redis

  1. 直接启动

直接运行redis-server即可启动Redis

  1. 通过初始化脚本启动Redis

在Redis源代码目录的utils文件夹中有一个名为redis_init_script的初始化脚本文件。需要配置Redis的运行方式和持久化文件、日志文件的存储位置。步骤如下:

2.1 配置初始化脚本

首先将初始化脚本复制到/etc/init.d 目录中,文件名为 redis_端口号,其中端口号表示要让Redis监听的端口号,客户端通过该端口连接Redis。然后修改脚本第6行的REDISPORT变量的值为同样的端口号。

2.2 建立以下需要的文件夹

|目录名|Value|

|/etc/redis|存放Redis的配置文件|

|/var/redis/端口号|存放Redis的持久化文件|

以上是需要创建的两个文件以及文件说明,如果没有创建则创建

2.3 修改配置文件

首先将配置文件模板(redis-4.0.2/redis.conf)复制到/etc/redis 目录中,以端口号命名(如“6379.conf”),然后按照下表对其中的部分参数进行编辑。

现在也可以使用下面的命令来启动和关闭Redis了

/etc/init.d/redis_6379 start
/etc/init.d/redis_6379 stop

让Redis随系统自动启动,这还需要对Redis初始化脚本进行简单修改,执行命令:

vim /etc/init.d/redis_6379

在打开的redis初始化脚本文件头部第四行的位置,追加下面两句


# chkconfig: 2345 90 10 
# description: Redis is a persistent key-value database    

//设置开机执行redis脚本

chkconfig redis_6379 on

通过设置开机启动的操作后,以后也可以直接用下面的命令对Redis进行启动和关闭了,如下

service redis_6379 start

service redis_6379 stop

经过上面的部署操作后,系统重启,Redis也会随着系统自动启动,并且上面的步骤里也配置了Redis持久化,下次启动系统或Redis时,有缓存数据不丢失的好处。

停止Redis

考虑到 Redis 有可能正在将内存中的数据同步到硬盘中,强行终止 Redis 进程可能会导致数据丢失。正确停止Redis的方式应该是向Redis发送SHUTDOWN命令,方法为:

redis-cli SHUTDOWN

当Redis收到SHUTDOWN命令后,会先断开所有客户端连接,然后根据配置执行持久化,最后完成退出。
Redis可以妥善处理 SIGTERM信号,所以使用 kill Redis 进程的 PID也可以正常结束Redis,效果与发送SHUTDOWN命令一样。

测试客户端连接

测试远程连接

这里需要将redis里的配置文件端口绑定注释掉

如果设置后,依然无法连接,请检查防火墙

设置redis 密码

临时密码

查看当前密码

config get requirepass

此图说明没有设置密码

设置密码

config set requirepass password

永久设置

编辑redis配置文件

取消这里注释,设置你的密码,重启redis

附录:redis常用配置注释:


# 关闭保护模式
protected-mode no
# ip地址
bind 192.168.1.230
# 端口
port 6379
# 守护进程开启,默认服务从后台启动
daemonize yes
# pid文件
pidfile /redis/pid/redis-6379.pid
# 日志级别
loglevel verbose
# 日志文件位置
logfile /redis/log/redis-6379.log
## redis持久化rdb,AOF
# redis持久化文件路径,默认为当前路径
dir /redis/data
# redis持久化文件名称
dbfilename dump-6379.rdb
# 开启AOF
appendonly yes
# AOF文件名称
appendfilename "appendonly-6379.aof"
# 子进程在做rewrite时,主进程不调用fsync(由内核默认调度)
no-appendfsync-on-rewrite yes
## REPLICATION
# 当slave与master断开连接,slave继续提供服务
slave-serve-stale-data yes
slave-read-only yes
# slave ping master的时间间隔,单位为秒
repl-ping-slave-period 1
# 复制超时,单位为秒,须大于repl-ping-slave-period的值
repl-timeout 10
## Redis cluster
# 关闭集群配置
# cluster-enabled yes
# 节点配置文件,这个文件是服务启动时自己配置创建的
cluster-config-file nodes-6379.conf
# 集群中各节点相互通讯时,允许"失联"的最大毫秒数,如果超过没向其它节点汇报成功,就认为该节点已挂
cluster-node-timeout 5000
# 将该项设置为0,不管slave节点和master节点间失联多久都会一直尝试failover
cluster-slave-validity-factor 0
# slave ping master的时间间隔,单位为秒
repl-ping-slave-period 1

Mongodb 安装

原文地址:https://www.cnblogs.com/lonelyxmas/p/10363823.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


文章浏览阅读552次。com.mongodb.MongoQueryException: Query failed with error code 292 and error message 'Executor error during find command :: caused by :: Sort exceeded memory limit of 104857600 bytes, but did not opt in to external sorting.' on server 11.51.141.63:27017 _mongodb 大文件 下载失败
文章浏览阅读635次,点赞9次,收藏8次。MongoDB 是一种 NoSQL 数据库,它将每个数据存储为一个文档,这里的文档类似于 JSON/BSON 对象,具体数据结构由键值(key/value)对组成。
文章浏览阅读2.1k次。和。_mongodb 日期类型
文章浏览阅读1.7k次。Scalestack等客户期待使用MongoDB Atlas Vector Search和Amazon Bedrock构建下一代应用程序
文章浏览阅读970次。SpringBoot整合中间件mongodb、ES_springboot3 elasticsearch json数据
文章浏览阅读673次。MongoDB 简介_尚医通sql
文章浏览阅读1k次,点赞8次,收藏9次。官网下载MongoDB安装包后进行解压(因了解并不深入,故暂不进行详细说明,自行查找其他安装方法,后期了解深入后将进行该教程的完善)在bin目录下使用命令启动:./mongod --config …/mongodb.conf。该文章任然处于完善中,如果存在错误遗漏的地方,欢迎私信联系。安装相关的nuget包后即可通过以下方法连接数据。YX9010_0@的第二十篇文章。
文章浏览阅读1.2k次,点赞17次,收藏26次。社交场景, 使用 MongoDB 存储存储用户信息, 以及用户发表的朋友圈信息, 通过地理位置索引实现附近的人, 地点等功能.游戏场景, 使用 MongoDB 存储游戏用户信息, 用户的装备, 积分等直接以内嵌文档的形式存储, 方便查询, 高效率存储和访问.物流场景, 使用 MongoDB 存储订单信息, 订单状态在运送过程中会不断更新, 以 MongoDB 内嵌数组的形式来存储, 一次查询就能将订单所有的变更读取出来.物联网场景, 使用 MongoDB 存储所有接入的智能设备信息, 以及设备汇报的日
文章浏览阅读686次。您可以使用 update_one() 方法来更新 MongoDB 中调用的记录或文档。update_one() 方法的第一个参数是 query 对象,用于定义要更新的文档。注释:如果查询找到多个记录,则仅更新第一个匹配项。第二个参数是定义文档新值的对象。_python 更新 mongodb 数据
文章浏览阅读1.3k次。首先来学习一下nosql这里安装就不进行介绍 只记录一下让自己了解mongodb。_nosql注入
文章浏览阅读4.1k次,点赞8次,收藏7次。在data的目录下,创建一个db文件。因为启动MongoDB服务之前必须创建数据库文件的存放文件夹,否则命令不会自动创建,而且不能启动成功。第一步:安装时,Custom是指可以自定义安装路径,然后傻瓜式安装即可(注意:先不要安装图形化工具,否则安装时间会特别长):如果要想连接成功,必须要开服务,即mongod -dbpath C:MongoDBdatadb的cmd要一直开着。然后回车,ctrl+F输入port找到端口号,一般为:27017。打开命令行,然后找到bin文件地址,并输入。_mongodb windows安装
文章浏览阅读5.1k次,点赞3次,收藏43次。详细介绍MongoDB数据库的基本知识,安装方法,基本操作,_mongodb数据库
文章浏览阅读3.2k次。安装教程翻看以往文章。_navicat 连接mongodb
文章浏览阅读426次,点赞9次,收藏12次。win10开放端口:https://blog.csdn.net/m0_43605481/article/details/119255256。我的是阿里云服务器,所以直接在安全组中加入规则,端口范围:27017,授权对象:0.0.0.0。windows在mongodb安装文件夹的bin文件夹中的mongod.cfg。数据库名字是test,打算创建一个用户,账号aaa,密码bbb,权限readWrite。因为该用户是创建在test数据库的,所以在最后要加上test。O了,然后恢复了test的数据。
文章浏览阅读1.1k次。聚合操作主要用于处理数据并返回计算结果。聚合操作将来自多个文档的值组合在一起,按条件分组后,再进行一系列操作(如求和、平均值、最大值、最小值)以返回单个结果。MongoDB的聚合查询​聚合是MongoDB的高级查询语言,它允许我们通过转化合并由多个文档的数据来生成新的在单个文档里不存在的文档信息。MongoDB中聚合(aggregate)主要用于处理数据(例如分组统计平均值、求和、最大值等),并返回计算后的数据结果,有点类似sql语句中的count(*)、groupby。..._如何将几个db的数据统整在一起做查询
文章浏览阅读680次,点赞7次,收藏8次。(2)application.properties配置文件。(4)UserService类。(5)测试和测试结果。
文章浏览阅读1k次,点赞17次,收藏25次。Studio 3T 2023.9 (macOS, Linux, Windows) - MongoDB 的专业 GUI、IDE 和 客户端,支持自然语言查询_mongodb客户端
文章浏览阅读1.1k次,点赞32次,收藏27次。插件式的存储引擎架构可以实现 Server 层和存储引擎层的解耦,可以支持多种存储引擎,如 MySQL 既可以支持 B-Tree 结构的 InnoDB 存储引擎,还可以支持 LSM 结构的 RocksDB 存储引擎。MongoDB 中的记录就是一个 BSON 文档,它是由键值对组成的数据结构,类似于 JSON 对象,是 MongoDB 中的基本数据单元。的简称,是 JSON 文档的二进制表示,支持将文档和数组嵌入到其他文档和数组中,还包含允许表示不属于 JSON 规范的数据类型的扩展。
文章浏览阅读5.1k次,点赞6次,收藏96次。本文设计了一种基于智能室内温度控制的自动调速风扇。以STM32系列单片机为核心主控板,通过程序代码驱动和使用温度传感器模块实现对环境温度的实时监测,并可以实时显示环境温度。同时,可以设置温度检测的上下警告值,根据需求自行调节。_stm32 温控风扇
文章浏览阅读898次,点赞13次,收藏21次。在MongoDB中,我们使用find()和find_one()方法来在集合中查找数据,就像在MySQL数据库中使用SELECT语句来在表中查找数据一样。_pymongo find_one