​Linux Ubuntu环境下安装配置Docker 和Docker、compose、mysql、中文版portainer

​Linux Ubuntu环境下安装配置Docker 和Docker、compose、mysql、中文版portainer

这篇文章探讨了在Linux Ubuntu环境下安装和配置Docker及其相关工具的过程。首先介绍了Docker的基本概念,然后详细讲解了在Ubuntu系统上的安装步骤。随后,文章涵盖了Docker Compose的配置,使读者能够更高效地管理多个Docker容器。此外,文章还包括了在Docker环境中部署和配置MySQL数据库的方法,以满足各种应用的数据存储需求。最后,文章介绍了中文版Portainer的安装和配置,为用户提供了一个友好的图形化界面,使Docker容器的管理变得更加直观和便捷。通过这些内容,读者将能够迅速在Ubuntu系统上搭建强大的Docker环境,同时利用相关工具更方便地进行容器化应用的开发和部署。

首先环境准备:

下载Ubuntu20.04.4版本并打开vmare16虚拟机(我用的这个版本)

iso镜像名称:ubuntu-20.04.4-desktop-amd64.iso

其它版本的ubuntu可以去官网自行下载:

https://ubuntu.com/

为了避免出现其它环境问题先卸载旧版本(纯净镜像可以忽略此步骤):

 sudo apt-get remove docker docker-engine docker.io containerd runc
 rm -rf /var/lib/docker
 rm -rf /var/lib/containerd

安装docker

sudo apt-get update
sudo apt install apt-transport-https ca-certificates curl software-properties-common

或者按照官方的命令:

sudo apt-get install ca-certificates curl gnupg lsb-release

添加Docker’s official GPG key

sudo mkdir -p /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
sudo chmod a+r /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

设置国内镜像仓库

vim /etc/docker/daemon.json

添加以下内容

{
  "registry-mirrors": ["https://kuamavit.mirror.aliyuncs.com",
  "https://registry.docker-cn.com", 
  "https://docker.mirrors.ustc.edu.cn"],
  "max-concurrent-downloads": 10,
  "storage-driver": "overlay2",
  "graph": "/data/docker",
  "log-driver": "json-file",
  "log-level": "warn",
  "log-opts": {
    "max-size": "10m",
    "max-file": "3"
    }
}

查看是否更改为国内的镜像仓库:

docker info

docker守护进程启动的时候,会默认赋予名字为docker的用户组读写Unix socket的权限,因此只要创建docker用户组,

并将当前用户加入到docker用户组中,那么当前用户就有权限访问Unix socket了,进而也就可以执行docker相关命令。

sudo groupadd docker   

  #添加docker用户组

sudo gpasswd -a $USER docker  

   #将登陆用户加入到docker用户组中

newgrp docker

    #更新用户组

就没有了error报错:

由于容器的环境比较精简不能编辑,我们可从本机编辑文件复制到容器

   

docker cp /root/index.html tomcat-8080:/usr/local/tomcat/webapps/

运行一个docker redis 容器 进行 端口映射 两个数据卷挂载 设置开机自启动

例子

docker run -d -p 6379:6379 --name redis506 --restart=always  -v /var/lib/redis/data/:/data -v /var/lib/redis/conf/:/usr/local/etc/redis/redis.conf  redis:5.0.5 --requirepass "password"

设置随服务启动而自启动 systemctl enable docker

安装 Docker Compose

sudo curl -L "https://github.com/docker/compose/releases/download/v2.12.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

#可以自己选定版本号安装我选的是v2.12.2

sudo ln -s ~/.docker/cli-plugins/docker-compose /usr/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose  

 //设置权限

最底下显示镜像地址就是生效

查看docker compose

运行 Docker Compose

下载tomcat的镜像

docker pull tomcat

docker images #显示所有镜像

创建tomcat容器

docker run -d --name tomcat-8080 -p 8080:8080 tomcat
docker run -d --name tomcat-8081 -p 8081:8080 tomcat

进入容器配置服务

docker exec -it tomcat-8080 bash

#为了镜像的简洁性,tomcat删除了非必要的文件

进入webapps下

mkdir ROOT
echo '<h1>8080!!!</h1>'>>index.html 
echo '<h1>8081!!!</h1>'>>index.html

#由于最小化没有vi命令,使用打印命令写入文件。

防火墙放行

firewall-cmd --zone=public --add-port=8080/tcp --permanent
firewall-cmd --zone=public --add-port=8081/tcp --permanent

配置docker数据卷

数据卷:是一个可供一个或多个容器使用的特殊目录。

1、docker run -v 本机存放路径:容器内的存放路径 -d --name -p *:* 镜像

例子:

docker run -d -p 8080:8080 --name Tomcat-8080 -v /root/docker-vloumn/qfnj:/usr/local/tomcat/webapps/qfnj tomcat

Docker安装nginx

nginx目录

/usr/sbin/nginx

/usr/lib/nginx

/etc/nginx      nginx的配置文件

/usr/share/nginx     nginx静态html5文件

nginx容器创建,并创建对应的映射关系

docker run -d -p 80:80 --name nginx-damoe -v /usr/local/nginx/html:/usr/local/nginx/html -v /user/local/nginx/conf/nginx.conf:/etc/nginx/conf.d/deafault.conf -v /usr/local/nginx/logs:/var/log/nginx nginx

docker中安装Mysql

docker pull mysql:8.0.27

docker run -d --name Mysql-3306 -p 3306-3306 -e MYSQL_ROOT_PASSWORD='123456' mysql:8.0.27

-p 13306:3306                      将容器的 3306 端口映射到主机的 3306 端口

--name  Mysql-3306                    启动后容器名

-e MYSQL_ROOT_PASSWORD='123456'   初始化 root 用户的密码

docker中部署Mysql

 docker pull mysql:8.0.27

创建容器并运行:

docker run -d --name Mysql-3306 -p 3306-3306 -e MYSQL_ROOT_PASSWORD='123456' mysql:8.0.27

-p 3306:3306                      将容器的 3306 端口映射到主机的 3306 端口

--name  Mysql-3306                    启动后的容器名

-e MYSQL_ROOT_PASSWORD='123456'   初始化 root 用户的密码

Docker中运行mysql,避免中文输入问题:

docker exec -it Mysql-3306 env LANG=C.UTF-8 bash
mysql  -uroot -p

输入密码:123456进入mysql

展示数据库:

show databases;

使用mysql数据库:

use mysql;

查看用户信息:

SELECT `Host`,`User` FROM user;

MySQL默认只允许root账户在本地登录,如果要在其他机器上连接mysql,必须修改root允许远程连接,或者添加一个允许远程连接的账户

因为拉取的mysql镜像是比较新版本的,当使用grant权限列表on数据库to '用户名'@'访问主机" identified by '密码';时会出现.……ear 'identified by '密码" at line1"这个错误

因为新版的的mysql版本已经将创建账户和赋予权限的方式分开了。

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION ;
flush privileges;

创建myx数据库并使用

#下面是我自己的一些设计表和建表,可忽略。

构建表结构并插入数据:

teacher表结构

字段名

字段描述

数据类型

主键

外键

非空

唯一

自增

id

编号

INT(4)

num

教工号

INT(10)

name

姓名

VARCHAR(20)

sex

性别

VARCHAR(4)

birthday

出生日期

DATETIME

address

家庭住址

VARCHAR(50)

(1)teacher表的创建:

create table teacher(

id int(4) not null unique auto_increment,

num int(10) not null unique,

name varchar(20) not null,

sex varchar(4) not null,

birthday datetime,

address  varchar(50),

primary key(id)

)engine = InnoDB default charset = utf8 collate = utf8_bin;

然后向teacher表中插入记录。

insert into teacher values(1, 1001, '张三', '男', '1984-11-08', '北京市昌平区'),(2, 1002, '李四', '女', '1970-01-21', '北京市海淀区'),(3, 1003, '王五', '男', '1976-10-30', '北京市昌平区'),(4, 1004, '赵六', '男', '1980-06-05', '北京市顺义区');

查询teacher表数据:

防火墙放行3306

firewall-cmd --zone=public --add-port=3306/tcp --permanent
firewall-cmd --reload 

dockerfile配置demo1

1、创建存放Dockerfile文件的文件夹

mkdir -p /usr/local/docker/demo1/

2、编写Dockerfile文件 (注:Dockerfile文件是严格区分大小写的)

FROM tomcat 

#借助tomcat的镜像

RUN mkdir -p /usr/local/tomcat/webapps/ROOT/ 

#创建ROOT目录

RUN echo  "Good morning, and in case I don't see you, Good afternoon, Good evening, And good night.">/usr/local/tomcat/webapps/ROOT/index.html

#使用 echo 写入创建内容

WORKDIR /usr/local/tomcat 

#跳转到/usr/local/tomcat目录

3、构建Dockerfile镜像 -t 指定构建镜像名称

docker build -t demo1 .或绝对路径

4、创建容器,测试镜像

docker run -d --name demo1-8080 -p 8080:8080 demo1

Dockerfile案例七、配置demo1:2.0

1、创建demo2文件夹

mkdir -p /usr/local/docker/demo1:2.0/

2、编写demo2的Dockerfile文件

FROM tomcat

WORKDIR /usr/local/tomcat/webapps/ROOT/

RUN rm -rf *

RUN echo "<h1>Hello world</h1>">/usr/local/tomcat/webapps/ROOT/index.html

3、创建镜像

docker build -t demo2 /usr/local/docker/demo1:2.0/

4、创建容器,测试镜像

docker run -d --name demo1-8080 -p 8080:8080 demo1:2.0
  1. 测试

Dockerfile配置demo2 (学习COPY命令)

1、创建demo2文件夹

mkdir -p /usr/local/docker/demo2/

2、编写Dockerfile文件

FROM tomcat

WORKDIR /usr/local/tomcat/webapps

RUN mkdir ROOT

RUN rm -rf *

COPY 1.jpg /usr/local/tomcat/webapps/ROOT/

3、创建镜像

docker build -t demo2 .

4、创建容器,测试镜像

Dockerfile案例九

1、创建demo3文件夹

mkdir -p /usr/local/docker/demo3/

2、编写demo3的Dockerfile文件

FROM tomcat

RUN mkdir -p /usr/local/tomcat/webapps/ROOT

WORKDIR /usr/local/tomcat/webapps/ROOT

RUN rm -rf *

COPY qfnj.zip /usr/local/tomcat/webapps/ROOT/

RUN unzip qfnj.zip

RUN rm -rf qfnj.zip

WORKDIR /usr/local/tomcat

3、创建镜像

docker build -t demo3 .

4、创建容器,测试镜像

Dockerfile案例十、配置图形化

1、下载docker的中文图形化镜像

sudo su

cp  Portainer-CN.zip  /root

Portainer-CN中文界面包上传到root目录下下

sudo mkdir -p /root/portainer/{data,public}

在命令行root目录下输入下面代码

apt install unzip
unzip Portainer-CN.zip -d /root/portainer/public
docker run -d \

--net bridge \

-p 9000:9000 \

--restart=always \

-v /var/run/docker.sock:/var/run/docker.sock \

-v /root/portainer/data:/data \

-v /root/portainer/public:/public \

--name myportainer \

portainer/portainer

ip;9000  设置管理员密码,密码长度不少于八个字符设置好后网页右上角注销重新登录选择本地docker

OK,到此一些docker和docker-compose的部署和一些简单案例结束了,后面我还会继续更新相关大数据方面的内容。                                

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

DevEco Studio 鸿蒙(HarmonyOS)项目结构

DevEco Studio 鸿蒙&#xff08;HarmonyOS&#xff09;项目结构 一、操作环境 操作系统: Windows 10 专业版 IDE:DevEco Studio 3.1 SDK:HarmonyOS 3.1 二、项目结构 创建简单的Hello World移动应用项目结构如下图 由上到下说明各个文件夹的作用 .hvigor&#xff1a;存…

【HarmonyOS】【DevEco Studio】安装教程及环境配置问题解决

目录 一、DevEco Studio 安装二、配置环境ohmp安装报错问题解决方法一&#xff1a;注册表删除数值&#xff08;没解决&#xff09;方法二&#xff1a;进入DevEco Studio点击Settings进入设置&#xff08;没解决&#xff09;方法三&#xff1a;自己去官网下载ohmp的包安装&#…

opencv,C++中cv下的函数都无法解释,并且报错为链接器工具错误 LNK2001

检查链接器中的附加依赖项目 opencv_word4.81.lib (release 版本) opencv_word4.81d.lib (debug 版本) 要和这里相对应&#xff0c;不然就会报连接器的错误。

德语 Alt 代码表

德语的 Alt 代码表&#xff0c;请参考下图。 输入方法就是按住 Alt 键不松开&#xff0c;然后在小键盘上输入字符&#xff0c;松开 Alt 键&#xff0c;计算机就能输出上面的字符了。 德语 Alt 代码表 - 系统容器 - iSharkFly德语的 Alt 代码表&#xff0c;请参考下图。 输入方…

13.Spring 整合 Kafka + 发送系统通知 + 显示系统通知

目录 1.Spring 整合 Kafka 2.发送系统通知 2.1 封装事件对象 2.2 开发事件的生产者和消费者 2.3 触发事件&#xff1a;在评论、点赞、关注后通知​编辑 3.显示系统通知 3.1 通知列表 3.1.1 数据访问层 3.1.2 业务层 3.1.3 表现层 3.2 开发通知详情 3.2.1 开发数据…

科技赋能医疗设备管理提质增效,实现医院高质量发展

近日&#xff0c;苏州阿基米德网络科技有限公司与医疗领域头部级媒体健康界&#xff0c;联合举办“数智为擎 提质增效——医学装备智慧管理创新发展论坛”的直播活动。 直播现场&#xff0c;来自上海交通大学医学院附属同仁医院、中华医学会航海医学分会、苏州阿基米德的专家们…

人工智能导论习题集(3)

第五章&#xff1a;不确定性推理 题1题2题3题4题5题6题7题8 题1 题2 题3 题4 题5 题6 题7 题8

大数据机器学习深度解读DBSCAN聚类算法:技术与实战全解析

大数据机器学习深度解读DBSCAN聚类算法&#xff1a;技术与实战全解析 一、简介 在机器学习的众多子领域中&#xff0c;聚类算法一直占据着不可忽视的地位。它们无需预先标注的数据&#xff0c;就能将数据集分组&#xff0c;组内元素相似度高&#xff0c;组间差异大。这种无监…

BSN实名DID服务发布会在北京召开

12月12日&#xff0c;由国家信息中心、公安部第一研究所联合主办&#xff0c;中国移动通信集团有限公司、区块链服务网络&#xff08;BSN&#xff09;发展联盟、中关村安信网络身份认证产业联盟&#xff08;OIDAA&#xff09;承办的“BSN实名DID服务发布会”在北京召开&#xf…

DevExpress WinForms Pivot Grid组件,一个类似Excel的数据透视表控件(二)

界面控件DevExpress WinForms的Pivot Grid组件是一个类似Excel的数据透视表控件&#xff0c;用于多维(OLAP)数据分析和跨选项卡报表。在上文中&#xff08;点击这里回顾>>&#xff09;我们介绍了DevExpress WinForms Pivot Grid组件的性能、分析服务、数据塑造能力等&…

【数据结构】哈希经典应用:布隆过滤器(哈希+位图)——[深度解析](9)

前言 大家好吖&#xff0c;欢迎来到 YY 滴 数据结构 系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过C的老铁 主要内容含&#xff1a; 欢迎订阅 YY滴 数据结构 专栏&#xff01;更多干货持续更新&#xff01;以下是传送门&#xff01; 目录 一.布隆过滤器产生的…

修改Element UI可清空Input的样式

如图所示&#xff0c;修改Input右侧的清空按钮位置&#xff1a; <el-input class"create-catalog-ipt"placeholder"请输入相关章节标题"v-model"currentCatalogTitle"clearable /> // SCSS环境 ::v-deep {.create-catalog-ipt {input {he…

华为云之轻松搭建 Nginx 静态网站

华为云之轻松搭建 Nginx 静态网站 一、本次实践介绍1. 本次实践目的2. 本次实践环境 二、ECS弹性云服务器介绍三、准备实践环境1. 预置环境2. 查看ECS服务器的账号密码信息3. 登录华为云4. 远程登录ECS服务器 四、安装配置 Nginx1. 安装nginx2. 启动nginx3. 浏览器中访问nginx服…

【ARM Trace32(劳特巴赫) 使用介绍 14 -- Go.direct 介绍】

请阅读【Trace32 ARM 专栏导读】 文章目录 Trace32 Go.directGo配合程序断点使用Go 配合读写断点使用Go 快速回到上一层函数 System.Mode Go Trace32 Go.direct TRACE32调试过程中&#xff0c;会经常对芯片/内核进行控制&#xff0c;比如全速运行、暂停、单步等等。这篇文章先…

CentOS 7.x操作系统的ECS云服务器上搭建WordPress网站

WordPress是使用PHP语言开发的博客平台&#xff0c;在支持PHP和MySQL数据库的服务器上&#xff0c;您可以用WordPress架设自己的网站&#xff0c;也可以用作内容管理系统&#xff08;CMS&#xff09;。本教程介绍如何在CentOS 7.x操作系统的ECS实例上搭建WordPress网站。 背景…

服务器漏洞防护措施有哪些?

随着互联网的普及和发展&#xff0c;服务器在各个领域的应用越来越广泛&#xff0c;同时也面临着越来越多的安全威胁。服务器漏洞一旦被攻击者利用&#xff0c;不仅可能导致数据泄露、系统崩溃等严重后果&#xff0c;还可能影响到企业的正常运营和声誉。因此&#xff0c;加强服…

山海鲸可视化软件:选择合适的图表,让数据可视化更高效

作为一名山海鲸可视化软件的开发者&#xff0c;我深知选择合适的图表对于数据可视化的重要性。下面我将从开发者的角度&#xff0c;分享一些关于如何选择合适可视图表的建议。 首先&#xff0c;我们需要明确数据可视化的目标。不同的图表类型具有不同的特点和适用场景&#xff…

中海达亮相能源北斗与时空智能创新技术应用大会

12月7日-8日&#xff0c;2023年能源北斗与时空智能创新技术应用大会暨鹭岛论坛在厦门举办。本次活动以“能源北斗时空智能”为主题&#xff0c;由中关村智能电力产业技术联盟、中国能源研究会、中国卫星导航定位协会、中国电力科学研究院有限公司、国网信息通信产业集团有限公司…

docker使用详解

介绍 Docker是一个开源的应用容器引擎&#xff0c;让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中&#xff0c;然后发布到任何流行的Linux或Windows操作系统的机器上&#xff0c;也可以实现虚拟化。 Docker基于轻量级虚拟化技术&#xff0c;整个项目基于Go语言开…

datax-自定义json遇到数据库字段名为关键字

一、背景 源数据库&#xff1a;pg 目标数据库&#xff1a;hive 问题&#xff1a; 自定义json时因pg表字段中包含desc的字段所以报错 二、定位问题 很明显&#xff0c;desc是关键字&#xff0c;所以报错 三、解决方案 将自定义json中的双引号调整成单引号&#xff0c;关键…