mac用Homebrew安装MySQL并配置远程登录

1. 简介

MySQL 是一个开源的关系型数据库管理系统(RDBMS),由瑞典 MySQL AB 公司开发,后被 Oracle 公司收购。MySQL 使用 SQL(Structured Query Language)作为查询语言,并提供了强大的功能和性能,被广泛应用于各种 Web 应用程序和企业级应用程序中。

以下是 MySQL 的一些主要特点和优势:

  1. **开源和免费:**MySQL 是开源软件,可以免费使用,并且有一个活跃的开源社区支持和维护它。

  2. **跨平台:**MySQL 可以在多种操作系统上运行,包括 Linux、Windows、macOS 等。

  3. **高性能:**MySQL 是一个高性能的数据库系统,能够处理大量的并发连接和请求,并且具有优化查询和存储引擎等功能。

  4. **可靠性和稳定性:**MySQL 是一个稳定可靠的数据库系统,拥有成熟的架构和可靠的数据存储机制,能够保证数据的安全性和完整性。

  5. **可扩展性:**MySQL 支持水平和垂直扩展,可以轻松地扩展以满足不同规模和需求的应用程序。

  6. **丰富的功能:**MySQL 提供了丰富的功能和工具,包括事务处理、存储过程、触发器、索引、备份和恢复等功能,能够满足各种复杂的业务需求。

  7. **广泛的应用:**MySQL 被广泛应用于 Web 开发、企业级应用程序、云计算、大数据等领域,是世界上最流行的数据库管理系统之一。

总的来说,MySQL 是一个强大、稳定、可靠且易于使用的关系型数据库管理系统,适用于各种规模和类型的应用程序开发。

2. 安装

没有安装brew的,可以参考mac安装Homebrew
要通过 Homebrew 安装并启动 MySQL,以及设置远程登录,可以按照以下步骤进行:

  1. **安装 MySQL:**首先,在终端中执行以下命令来安装 MySQL:
brew install mysql
  1. **启动 MySQL 服务:**安装完成后,你可以使用以下命令启动 MySQL 服务:
brew services start mysql
  1. 设置 root 密码:
    运行以下命令启动 MySQL 安全脚本,该脚本将帮助你设置 root 密码和其他安全选项:
mysql_secure_installation
  1. 允许root远程登录:
    首先,使用以下命令以 root 用户身份登录 MySQL:
mysql -u root -p

然后输入你之前设置的 root 密码。
接着,使用以下 SQL 命令允许 root 用户从远程主机登录:


GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'your_password' WITH GRANT OPTION;
FLUSH PRIVILEGES;

将 ‘your_password’ 替换为你想要设置的密码。

注意:

从 MySQL 8 开始,您不再可以(隐式)使用该GRANT命令创建用户。请改用CREATE USER,后跟GRANT语句:
CREATE USER ‘root’@‘%’ IDENTIFIED BY ‘your_password’;
GRANT ALL PRIVILEGES ON . TO ‘root’@‘%’ WITH GRANT OPTION;
FLUSH PRIVILEGES;

  1. **设置远程登录:**默认情况下,MySQL 不允许远程登录。要允许远程登录,需要进行以下步骤:
  • **编辑 MySQL 配置文件:**使用文本编辑器打开 MySQL 的配置文件 my.cnf,该文件通常位于 /usr/local/etc/my.cnf/etc/my.cnf。如果不存在,可以根据需要创建该文件。
sudo open -e /usr/local/etc/my.cnf
  • **添加配置:**在文件中添加以下内容,表示允许远程登录:
[mysqld]
bind-address = 0.0.0.0

这会将 MySQL 绑定到所有可用的 IP 地址,允许远程访问。

  • **重启 MySQL 服务:**保存并关闭文件后,重启 MySQL 服务以应用配置更改:
brew services restart mysql
  1. **登录 MySQL 并创建远程用户:**现在,你可以使用 MySQL 客户端登录到 MySQL 服务器,并创建一个允许远程访问的用户。

    • 首先,使用以下命令登录到 MySQL 服务器,你将需要输入你的 MySQL root 用户密码:
    mysql -u root -p
    
    • 登录成功后,可以执行以下 SQL 命令创建一个新的用户,例如 remote_user,并授予该用户远程登录和所有权限:
    CREATE USER 'remote_user'@'%' IDENTIFIED BY 'your_password';
    GRANT ALL PRIVILEGES ON *.* TO 'remote_user'@'%' WITH GRANT OPTION;
    FLUSH PRIVILEGES;
    

    'your_password' 替换为你想要设置的密码。

    报错:ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
    原因:自定义密码太简单,出现了不符合密码策略的问题
    查看mysql 初始的密码策略

SHOW VARIABLES LIKE 'validate_password%';

在这里插入图片描述

如果遇到

ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.

修改策略,及密码长度

set global validate_password.policy=0;
set global validate_password.length=1;

validate_password_policy取值

0 or LOW     只验证长度
1 or MEDIUM  验证长度、数字、大小写、特殊字符
2 or STRONG  验证长度、数字、大小写、特殊字符、字典文件

报错:Authentication plugin ‘caching_sha2_password’ cannot be loaded
错误信息:

MySQL said: Authentication plugin 'caching_sha2_password' cannot be loaded: dlopen(/usr/local/lib/plugin/caching_sha2_password.so, 0x0002): tried: '/usr/local/lib/plugin/caching_sha2_password.so' (no such file), '/usr/local/Cellar/mysql/8.3.0_1/lib/plugin/caching_sha2_password.so' (no such file)

原因:

  • 不是客户端Navicat的原因,是MySQL兼容问题,需要修改数据库的认证方式
  • MySQL8.0版本默认的认证方式是caching_sha2_password
  • MySQL5.7版本则为mysql_native_password。
  1. 解决办法1
    打开系统偏好设置,找到mysql,点击Initialize Database。
    输入你的密码。
    选择‘Use legacy password‘。
    重启mysql服务。
    重新使用Navicat链接数据库
  2. 解决办法2
    用终端连接MySQL,然后执行以下命令:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'yourpassword';
  1. 解决办法3
    修改my.cnf 文件,再重启MySQL:
sudo open -e /usr/local/etc/my.cnf
[mysqld]
default_authentication_plugin=mysql_native_password
  1. **验证远程登录:**现在,你应该能够从远程计算机使用 MySQL 客户端连接到你的 MySQL 服务器。你可以使用以下命令进行测试:
mysql -u remote_user -p -h your_mysql_server_ip

替换 'your_mysql_server_ip' 为你的 MySQL 服务器的 IP 地址。输入远程用户的密码,如果一切设置正确,你应该能够成功登录到 MySQL 服务器。

这样,你就完成了通过 Homebrew 安装并设置远程登录到 MySQL 服务器的过程。

3. 卸载

要通过 Homebrew 卸载 MySQL,你可以执行以下步骤:

  1. **停止 MySQL 服务:**首先,确保停止 MySQL 服务。在终端中执行以下命令:
brew services stop mysql
  1. **卸载 MySQL:**执行以下命令来卸载 MySQL:
brew uninstall mysql
  1. **删除 MySQL 数据文件和配置文件:**MySQL 的数据文件通常存储在 /usr/local/var/mysql/ 目录下。你可以手动删除该目录及其内容,以清除 MySQL 数据文件:
rm -rf /usr/local/var/mysql/
  1. **删除配置文件:**删除 MySQL 的配置文件,以及其他可能残留的文件:
rm -rf /etc/my.cnf
  1. **删除遗留文件:**运行以下命令,删除可能还残留在系统中的 MySQL 相关文件:
rm -rf ~/Library/Caches/Homebrew/mysql*
rm -rf ~/Library/Logs/Homebrew/mysql*
  1. **删除 MySQL 用户和组:**如果你创建了 MySQL 用户和组,你也可以将其删除:
sudo dscl . -delete "/Users/_mysql"
sudo dscl . -delete "/Groups/_mysql"

完成上述步骤后,MySQL 将被完全从你的 macOS 系统中卸载。请确保在删除任何文件之前备份重要数据。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/317295.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python安卓自动化pyaibote实践------学习通自动刷课

前言 欢迎来到我的博客 个人主页:北岭敲键盘的荒漠猫-CSDN博客 本文是一个完成一个自动播放课程,避免人为频繁点击脚本的构思与源码。 加油!为实现全部电脑自动化办公而奋斗! 为实现摆烂躺平的人生而奋斗!!&#xff…

Linux——socket套接字与udp通信

目录 一、理解IP地址与端口 二、socket套接字 三、TCP与UDP的关系 四、网络字节序 五、socket编程 1.socket()创建套接字 2.填充sockaddr_in 结构体 3.bind() 绑定信息 4.recvfrom()接收消息 5.sendto()发送消息 六、UdpServer代码 一、理解IP地址与端口 IP地址是In…

【C++】详解string类

目录 简介 框架 构造 全缺省构造函数 ​编辑 传对象构造函数 拷贝构造 析构函数 容量 size() capacity() empty() clear() reserve() ​编辑 resize() 遍历 检引用符号"[ ]"的重载 迭代器 begin() end() rbegin() rend(…

【触摸案例-控件不能响应的情况 Objective-C语言】

一、接下来,我们来说这个“控件不能响应的情况”, 1.素材里边,有一个“不接受用户交互的情况”,这么一个代码,把它打开, 把这个项目啊,复制过来,改一个名字,叫做“04-控件不能响应的情况”, 打开之后,command + R,运行一下, 在storyboard上,你也可以看得出来,我…

智慧农业设备——虫情监测系统

随着科技的不断进步和农业生产的日益现代化,智慧农业成为了新时代农业发展的重要方向。其中,虫情监测系统作为智慧农业的重要组成部分,正逐渐受到广大农户和农业专家的关注。 虫情监测系统是一种基于现代传感技术、图像识别技术和大数据分析技…

链表-----返回倒数第K个节点回文结构的判断相交链表

目录 1.返回倒数第K个节点 2.回文结构的判断 3.相交链表的判断,返回交点 1.返回倒数第K个节点 (1)返回链表的第k个节点,我们这里的做法是定义两个指针,这两个指针之间相差的是k这个长度;这个过程的实现就…

Android手势识别面试问题及回答

问题 1: 如何在Android中实现基本的手势识别? 答案: 在Android中,可以通过使用GestureDetector类来实现基本的手势识别。首先需要创建一个GestureDetector的实例,并实现GestureDetector.OnGestureListener接口来响应各种手势事件&#xff0c…

创建SpringBoot和RabbitMQ的整合项目

文章目录 创建SpringBoot和RabbitMQ的整合项目首先快速创建一个maven项目引入SpringBoot整合rabbitMQ的依赖在src/main目录下创建resources目录并引入配置文件写消息发送者MessageSender写消息接收者MessageReceiver写RabbitMQConfig配置类写SpringBoot启动主类CommandLineRunn…

小剧场短剧影视小程序源码_后端PHP

项目运行截图 源码贡献 https://githubs.xyz/boot?app42 部署说明 linux/win任选 PHP版本:7.3/7.2(测试时我用的7.2要安装sg扩展 ) 批量替换域名http://video.owoii.com更换为你的 批量替换域名http://120.79.77.163:1更换为你的 这两个…

代码随想录算法训练营第60天|84.柱状图中最大的矩形

84. 柱状图中最大的矩形 题目链接:柱状图中最大的矩形 题目描述:给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为 1 。 求在该柱状图中,能够勾勒出来的矩形的最大面积。 解题思路&#…

24 JavaScript学习:this

this在对象方法中 在 JavaScript 中,this 的值取决于函数被调用的方式。在对象方法中,this 引用的是调用该方法的对象。 让我们看一个简单的例子: const person {firstName: John,lastName: Doe,fullName: function() {return this.firstN…

【webrtc】MessageHandler 3: 基于线程的消息处理:以sctp测试为例

消息处理可以用于模拟发包处理G:\CDN\rtcCli\m98\src\net\dcsctp\socket\dcsctp_socket_network_test.cc 这个实现中,onMessage还是仅对了一种消息进行处理,就是接收则模式下,打印带宽。当然,可能程序有多个消息,分别在不同的onmessage中执行?SctpActor:以一个恒定的速率…

C语言贪吃蛇项目

今天给大家带来一款简单的贪吃蛇游戏,一起随我来看看吧 游戏效果: 实现基本的功能: • 贪吃蛇地图绘制 • 蛇吃⻝物的功能:(上、下、左、右⽅向键控制蛇的动作) • 蛇撞墙死亡 • 蛇撞⾃⾝死亡 • 计算得分…

Flink 实时数仓(一)【实时数仓离线数仓对比】

前言 昨天技术面的时候,面试官说人家公司现在用的都是最新的技术,比如 Doris 等一些最新的工具,确实这些课是学校永远不会开设的,好在他说去了会带着我做一做。可是 ...... 学院这边确实不允许放人,唉,可惜…

Kubernetes 弃用Docker后 Kubelet切换到Containerd

containerd 是一个高级容器运行时,又名 容器管理器。简单来说,它是一个守护进程,在单个主机上管理完整的容器生命周期:创建、启动、停止容器、拉取和存储镜像、配置挂载、网络等。 containerd 旨在轻松嵌入到更大的系统中。Docke…

python项目入门新手攻略

最近工作需要接手了代码量比较大的python开发的项目,平时写python不多,记录一下如何熟悉项目。 分析调用流程-pycallgraph 因为代码量比较大,所以希望通过工具生成代码调用流程,因此用到了pycallgraph。 pycallgraph&#xff0…

windows Jenkins运行python+selenium打开浏览器一直无响应,运行中,还没有打开浏览器

一开始解决办法是把打开服务把Jenkins给禁用了 但是没有用,然后找到安装目录 C:\Program Files\Jenkins 在这个路径下,在地址栏输入cmd打开命令窗口运行Jenkins启动命令 java -jar jenkins.war --httpPort8080 打开浏览器进入链接 http://localhost:…

【Unity学习笔记】第十四 Prefab 概念解惑

目录 1 prefab、prefab变体、prefab覆盖和prefab 嵌套2 connect 与unpack3 prefab到底是什么,它和gameobject又有什么区别?4 为什么要用prefab?5 代码动态加载prefab6 为什么我unity PrefabUtility.InstantiatePrefab() 得到的是null7 Prefab…

Redis基本命令

目录 一、包含String、Set数据类型的基本命令 1、添加一个键值对 2、获取key所关联的字符串值 3、同时设置多个key-value 4、获取多个key对应的值 运行结果 5、将给定的value追加到原值的末尾 追加后效果 6、删除单个key 7、同时删除多个key 8、查询包含某个字符的k…

ubuntu入门

基础命令 cd 切换命令 ls 查看当前目录下所有的文件 cp a.c b.c 拷贝a.c 到 b.c touch a.c 创建a.c文件 mkdir file 创建文件夹file rm file 删除文件 rmdir 删除test文件夹 rmdir test/ mv 移动文件 mv a.c b.c 把a.c 替换成b.c ifconfig 查看电脑网络信息 rm xx 删…