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.mzph.cn/bicheng/5623.shtml

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

相关文章

C++——STL容器——vector

vector是STL容器的一种,和我们在数据结构中所学的顺序表结构相似,其使用和属性可以仿照顺序表的形式。vector的本质是封装了一个动态大小的数组,支持动态管理容量、数据的顺序存储以及随机访问。 1.前言说明 vector作为容器,应该…

安全再升级,亚信安慧AntDB数据库与亚信安全二次牵手完成兼容性互认证

日前,湖南亚信安慧科技有限公司(简称:亚信安慧)的产品与亚信科技(成都)有限公司(简称:亚信安全)再次携手,完成亚信安慧AntDB数据库与亚信安全IPoE接入认证系统…

「 网络安全常用术语解读 」SBOM主流格式SPDX详解

SPDX(System Package Data Exchange)格式是一种用于描述软件组件(如源代码)的规范,它提供了一种标准化的方法来描述软件组件的元数据,包括其许可证、依赖项和其他属性。SPDX最初由Linux基金会于2010年发起&…

复旦微JFM7VX690计算后IO接口模块,用于雷达信号处理、数据处理等需要高速密集计算的应用场景

计算后IO接口模块 1 介绍 1.1 产品概述 计算后IO接口模块主要由复旦微JFM7VX690型FPGA、国产以太网收发器YT8521、国产BMC芯片GD32F450、国产CPLD芯片EF2L45BG256B、国产内存颗粒等主要芯片组成,采用标准6U VPX尺寸设计。 本计算后IO接口模块主要用于雷达信号处…

Java面试八股之Java中数组有没有length()方法?String呢?为什么?

Java中数组有没有length()方法?String呢?为什么? 数组: 数组没有名为length()的方法,但有一个属性叫做length。可以通过数组名直接访问这个属性来获取数组的长度(即元素个数)。这是一个整数值&…

【redis】Redis数据类型(三)List类型

目录 List类型介绍特点 List数据结构附:3.2以前的版本(介绍一下压缩列表和双向链表)压缩列表ZipList双向链表LinkedList 常用命令lpush示例 lpushx示例 rpush示例 rpushx示例 LPOP示例 RPOP示例 BLPOP非阻塞行为阻塞行为相同的 key 被多个客户端同时阻塞在 MULTI/EX…

[笔试强训day06]

文章目录 NC10 大数乘法NC1 大数加法NC40 链表相加(二) NC10 大数乘法 NC10 大数乘法 #include <string> #include <vector> class Solution {public:string solve(string s, string t) {int m s.size(), n t.size();reverse(s.begin(), s.end());reverse(t.beg…

Matlab图像处理——基于BP神经网络的车牌标识识别系统

1. 数据集介绍 中国交通标志数据集&#xff1a; https://nlpr.ia.ac.cn/pal/trafficdata/detection.html 该数据集包含58类交通标志。 2. 数据处理 按照文件标签&#xff0c;将数据集划分了58类&#xff0c;如下&#xff1a; 对应的类别信息记录如下&#xff1a; 限速5km/…

企业计算机服务器中了rmallox勒索病毒怎么处理,rmallox勒索病毒处理建议

在网络技术不断发展的时代&#xff0c;网络在企业中的应用广泛&#xff0c;可以为企业带来更多的便利&#xff0c;大大提升了企业的生产效率&#xff0c;但网络作为虚拟世界&#xff0c;在为企业提供便利的同时&#xff0c;也为企业数据安全带来严重威胁。近期&#xff0c;云天…

【YOLO改进】换遍IoU损失函数之EIoU Loss(基于MMYOLO)

EIoU损失函数 设计原理 一、IoU的局限性 IoU&#xff08;Intersection over Union&#xff09;是一种常用于评估目标检测模型性能的指标&#xff0c;特别是在计算预测边界框与真实边界框之间的重叠程度时。然而&#xff0c;IoU存在一些局限性&#xff0c;尤其是当两个边界框…

[python趣味实战]----基于python代码实现浪漫爱心 დ

正文 01-效果演示 下图是代码运行之后的爱心显示结果&#xff1a; 下面的视频该爱心是动态效果&#xff0c;较为简洁&#xff0c;如果需要使用&#xff0c;可以进行完善&#xff0c;这里只是一个趣味实战&#xff0c;下面将对代码实现进行非常详细地描述&#xff1a; 浪漫爱心…

Java数据结构-模拟实现ArrayList

MyArrayList顺序结构&#xff1a; 接口和MyArrayList重写接口 接口 接口中的方法是很多类通用的&#xff0c;所以可以写到接口中 public interface IList {public void add(int data) ;// 在 pos 位置新增元素public void add(int pos, int data);// 判定是否包含某个元素p…

踏上R语言之旅:解锁数据世界的神秘密码(三)

多元相关与回归分析及R使用 文章目录 多元相关与回归分析及R使用一.变量间的关系分析1.两变量线性相关系数的计算2.相关系数的假设检验 二.一元线性回归分析的R计算三、回归系数的假设检验总结 一.变量间的关系分析 变量间的关系及分析方法如下&#xff1a; 1.两变量线性相关…

【C++程序员的自我修炼】string 库中常见的用法 (一)

唤起一天明月照我满怀冰雪浩荡百川流鲸饮未吞海 剑气已横秋 目录 string 库的简介 string 的一些小操作 构造函数的使用 拷贝构造的常规使用 指定拷贝内容的拷贝构造 拷贝字符串开始的前 n 个字符 用 n 个字符初始化 计算字符串的长度 string 的三种遍历方式 常规的for循环 op…

利用大型语言模型提升数字产品创新:提示,微调,检索增强生成和代理的应用

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

「笔试刷题」:字母收集

一、题目 描述 有一个 &#x1d45b;∗&#x1d45a; 的矩形方阵&#xff0c;每个格子上面写了一个小写字母。 小红站在矩形的左上角&#xff0c;她每次可以向右或者向下走&#xff0c;走到某个格子上就可以收集这个格子的字母。 小红非常喜欢 "love" 这四个字母。…

FFmpeg开发笔记(二十三)使用OBS Studio开启RTMP直播推流

OBS是一个开源的直播录制软件&#xff0c;英文全称叫做Open Broadcaster Software&#xff0c;广泛用于视频录制、实时直播等领域。OBS不但开源&#xff0c;而且跨平台&#xff0c;兼容Windows、Mac OS、Linux等操作系统。 OBS的官网是https://obsproject.com/&#xff0c;录制…

【报错处理】ib_write_bw执行遇到Couldn‘t listen to port 18515原因与解决办法?

要点 要点&#xff1a; ib默认使用18515端口 相关命令&#xff1a; netstat -tuln | grep 18515 ib_write_bw --help |grep port# server ib_write_bw --ib-devmlx5_1 --port88990 # client ib_write_bw --ib-devmlx5_0 1.1.1.1 --port88990现象&#xff1a; 根因&#xff…

为什么公共事业机构会偏爱 TiDB :TiDB 数据库在某省妇幼健康管理系统的应用

本文介绍了某省妇幼健康管理系统的建设和数据库架构优化的过程。原有的数据库架构使用了 StarRocks 作为分析层&#xff0c;但随着业务的发展&#xff0c;这套架构暴露出诸多痛点&#xff0c;不再适应妇幼业务的需求。为解决这些问题&#xff0c;该系统选择了将原有架构中的 St…

OBSERVER(观察者)-- 对象行为模式

意图&#xff1a; 定义对象间地一种一对多地依赖关系&#xff0c;当一个对象地状态发生改变时&#xff0c;所有对于依赖于它的对象都得到通知并被自动更新。 别名&#xff1a; 依赖(Dependents), 发布-订阅(Publish-Subsribe) 动机&#xff1a; 将一个系统分割成一系列相互协…