docker 学习之一 装MySQL 供远程使用 Linux
因为Linux发行版本的问题折腾了好久,尽量使用LTS的版本。其他版本有时候缺的东西太多了,对新手相当不友好。
大概花了几天实在没招了,下了个LTS的版本,再装时正常了。按照官方文档都可以搞定了。
使用这个版本的ubuntu-22.04.2-desktop-amd64.iso的,官网上下的,用虚拟机弄个上装了下,检查下有没有联网。
ping www.baidu.com
- 首先切root上,不知道前几个版本时不是也是这个原因,反正到处缺包报错。最后上这个直接切root。
#用户叫xman 在 xman-virtual-machine的机子上登录
xman@xman-virtual-machine:~$ su -
Password:
root@xman-virtual-machine:~#
输入 su - 会让你输入密码,输入当前账号的登录密码。切成root用户。安装权限最大,但是docker群组有些操作不了,文件夹也访问不全,
还要授权乱七八糟。
- 然后安装,找到官网 Install Docker Engine on Ubuntu
#清空历史版本
sudo apt-get remove docker docker-engine docker.io containerd runc
#更新下包管理器
sudo apt-get update
#允许https类型的通过
sudo apt-get install \
ca-certificates \
curl \
gnupg \
lsb-release
#Docker’s official GPG key
sudo mkdir -m 0755 -p /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
#设定存储库
echo \
"deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \
$(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
#更新包管理器
sudo apt-get update
#如果更新出错GPGkey有误
sudo chmod a+r /etc/apt/keyrings/docker.gpg
sudo apt-get update
#安装docker
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
#用默认的容器检查下是否安装成功
sudo docker run hello-world
以上都完了以后就代表安装成功,真真的门槛安装都吃力。
- 查一下本机对外提供服务的IP,使用这个建立个网桥
ip address
如果联网了,你大概能看到你的IP,作为对外通讯的IP

然后建立个网桥,作为容器和本机的通道,这样容器通过这个桥使用本机东西对外提供服务
#查看网桥的内容,一般有几个
docker network ls
#清空没用的网络
docker network prune
#如果一个网桥被使用中你删不掉需要先关掉容器,删除容器,然后删除
docker stop mycontainer1
docker rm mycontainer1
docker network prune
# 清除不用的网桥后大体干净了,就做个自己用本机对外提供服务的IP做
docker network create \
-o "com.docker.network.bridge.host_binding_ipv4"="192.168.139.129" \
br0
#检查下状态有没有问题
docker net ls
- 下载MySQL并安装
#查一下现有的镜像
docker images
#如果下来了直接装,没有下来就下一下,不写版本默认是last的
docker pull mysql
#然后安装
docker run -di --privileged=true -p 3306:3306 --network=br0 -v /home/mysql/log:/var/log/mysql -v /home/mysql/data:/var/lib/mysql -v /home/mysql/conf/my.cnf:/etc/mysql/my.cnf -v /home/mysql/mysql-files:/var/lib/mysql-files -e MYSQL_ROOT_PASSWORD=123456 --name my mysql
-di d 后台运行,有守护进程处理 i 可以交互 这个弄了以后就不用手动启动了
--privileged=true 提升权限,防止MySQL的有些目录没权限访问
-p 3306:3306 端口映射 主端口:容器端口 容器的口接到主机上对外提供服务
--network=br0 使用网桥 br0创建此容器,并对外提供服务
-v /home/mysql/log:/var/log/mysql
-v /home/mysql/data:/var/lib/mysql
-v /home/mysql/conf/my.cnf:/etc/mysql/my.cnf
-v /home/mysql/mysql-files:/var/lib/mysql-files
主机目录:容器目录,把容器的数据和配置文件挂载到主机上防止丢失和配置同步,这个是以前的如果需要改远程访问的改 my.cnf文件
-e MYSQL_ROOT_PASSWORD=123456 配置登录数据库root用户的密码是123456,到时候进容器可以用这个进数据库
--name my mysql 容器名称 容器创建依据的镜像名称
- 先进去看看容器,并且切到MySQL中看看允许远程访问不
#交互进去my容器中
docker exec -it my /bin/bash
#进入MySQL看看
mysql -uroot -p123456
#切到管理数据库
use mysql;
#查看下是否允许远程访问
select user,host from user;
#如果不允许改下
update user set host ='%' where user ='root';
#刷新权限
flush privileges;
#如果不想用这个自己建个用户
CREATE USER 'username'@‘%' IDENTIFIED BY '123';
#然后授权
grant all privileges on *.* to 'username'@'%' ;
#同样刷新一下
flush privileges;
#退出MySQL
exit;
#退出容器
exit
- 远程连接一下看看
在远程机器上输入IP连接一下貌似可以

至此搞完。
另外记录下vi的作业。linux的编辑器对windows转过来的很不友好。
#可以打开一个这个位置的cnf的文件
vi /home/bin/conf.cnf
#默认是命令模式,不支持输入字符,输入的都是命令
可以使用滚轮HJKL来移动到你想要的行列home|end也可以
移动了以后摁i以后进入编辑模式
shift+字符好像才可以输入想要的字符,一不注意就跑回命令模式了。
并且上下左右箭头是ABCD字符,
dd可以删除一行
delete可以删除一个字符
u是撤销更改
连按两次Esc可以切换到命令模式
想保存摁:
然后q!直接退出忽略更改
wq保存并退出
搞这玩意的时候最好确定你有权限动这个文件,要不费劲弄完,就笑了。
docker 学习之一 装MySQL 供远程使用 Linux的更多相关文章
- Linux学习5-安装mysql
前言 今天我们来学习一下如何在Linux下安装mysql 一:准备安装包 可以从http://www.mysql.com/downloads/官方网站下载到最新版本,本次安装的版本是mysql-5.7 ...
- Docker学习之搭建MySql容器服务
描述 MySQL 5.6 SQL数据库服务器Docker镜像,此容器映像包含用于OpenShift的MySQL 5.6 SQL数据库服务器和一般用法.用户可以选择RHEL和基于CentOS的图像.然后 ...
- Docker学习之安装mysql
1.从Docker检索mysql镜像 指令: docker search mysql 2.镜像下载 指令: docker pull mysql:5.7.19 3.查看本地镜像列表 指令: docker ...
- docker学习4-docker安装mysql环境
前言 docker安装mysql环境非常方便,简单的几步操作就可以了 拉取mysql镜像 先拉取mysql的镜像,可以在docker的镜像仓库找到不同TAG标签的版本https://hub.docke ...
- docker学习2-安装实践
windows上安装docker后,默认自动在后台运行,右下角有docker图标,鼠标右键点击出现菜单 可以查看docker版本,对一些基本项进行设置如下: 安装及具体操作参见官方文档: https: ...
- docker学习-01-安装docker
[root@localhost firstDocker]# cat /etc/centos-release CentOS Linux release 7.6.1810 (Core) [root@loc ...
- docker学习资料整理(持续更新中..)
docker最近可以说火得一踏糊涂,跟 51大神在交流技术的时候这个东西会多次被提到,当我们还玩vm+linux/freebsd的时候,人家已经上升到更高层次了,这就是差距,感觉好高大上的样子,技术之 ...
- [转]Docker学习之四:使用docker安装mysql
本文转自:https://blog.csdn.net/qq_19348391/article/details/82998391 Docker学习之一:注册Docker Hub账号 Docker学习之二 ...
- docker学习(5) 在mac中创建mysql docker容器
github上有一个专门的docker-libary项目,里面有各种各样常用的docker镜像,可以做为学习的示例,今天研究下其中mysql镜像的用法,国内镜像daocloud.io也能找到mysql ...
- Docker学习实践 - Docker安装MySql数据库
Docker安装MySQL数据库 1.Ubuntu安装MySQL安装 (1)安装编译源码需要的包 sudo apt-get install make cmake gcc g++ bison libnc ...
随机推荐
- 基于Java语言的编码问题了解
基于Java语言的编码问题了解 以下仅为本人工作.学习过程中所接触到的内容,不足之处欢迎指出. 近两天使用maven的tomcat插件,以及使用非插件版的tomcat部署项目时遇到了乱码问题,在解决乱 ...
- 查询某数据库的某字段存在于哪些表 mysql
select column_name,column_comment,data_type ,table_name from information_schema.columns where table ...
- 「SOL」Hamiltonian Cycle (AtCoder)
原来一般的四度图也没法快速构造哈密顿回路 QwQ # 题面 给定质数 \(P\) 和正整数 \(a,b\),构造一个长为 \(P\) 的数列 \(G=(g_1,g_2,\dots,g_P)\),满足: ...
- Excel Vlookup用法和常见报错#REF! #Value!
VLOOKUP(E2,$A$2:$C$5,2,FALSE) E2 为选中查找的条件 $A$2:$C$5 1为需要查找的区域,这个区域一般是固定的,所以要加上$符号 2这个区域可以在前面加上SHEET2 ...
- 48. Rotate Image via java
need to use scratch to find the pattern class Solution { public void rotate(int[][] matrix) { int n= ...
- vs2013如何添加扩展库函数
本文仅针对C和C++ vs2013下载C/C++编译器后,能够包含常见的头文件,stdlib.h,stdio.h,math.h这些.如果有其他需求例如:调用GL/glfw32.h,freeglut.h ...
- 双指针_Leetcode刷题_13/100
算法解释 双指针主要用于遍历数组,两个指针指向不同的元素,从而协同完成任务.也可以延伸到多个数组的多个指针. 若两个指针指向同一个数组,遍历的方向相同且不会相交,则也称为滑动窗口: 若两个指针指向同一 ...
- ucharts的区域图、折线图(有x轴的),修改x轴显示为隔一个显示
1.原本的显示方式: 2.想要的效果: 3.这边我使用的是uchart的组件,在uni_modules > qiun-data-charts > js_sdk > u-charts, ...
- Maven中的DependencyManagement 和 Dependencies
Maven 使用dependencyManagement 元素来提供了一种管理依赖版本号的方式. 通常会在一个组织或者项目的最顶层的父POM 中看到dependencyManagement 元素. 使 ...
- Spring系列之基于环境抽象-10
目录 Bean 定义配置文件 使用 `@Profile` XML Bean 定义配置文件 激活配置文件 默认配置文件 `PropertySource` 使用`@PropertySource` Envi ...