Docker安装MongoDB、MySQL、Jenkins、Gitlab、Nginx

安装MongoDB

1. 拉取镜像
$ sudo docker pull mongo 2. 运行镜像
$ sudo docker run --name mongo -p 27017:27017 -v /srv/mongodb/db:/data/db -v /srv/mongodb/backup:/data/backup -d mongo --auth 3. 进入mongo容器,
$ sudo docker exec -it mongo mongo admin 4. 添加用户
> db.createUser({
user: "admin",
pwd: "123456",
roles: [ { role: "userAdminAnyDatabase", db: "admin" } ],
mechanisms : ["SCRAM-SHA-1"]
}); 5. 修改用户权限
$ db.auth("admin", "123456")
$ db.grantRolesToUser("admin", [ { role:"root", db:"admin"} ]) ; 6. 查询用户
$ db.system.users.find();

安装MySQL

1. 拉去镜像
$ sudo docker pull mysql/mysql-server:5.6 2. 启动镜像
$ sudo docker run --name=mysql -p 3306:3306 --volume /etc/localtime:/etc/localtime --volume /srv/mysql/datadir:/var/lib/mysql:z -e MYSQL_ROOT_PASSWORD=123456 -d mysql/mysql-server:5.6 3. 配置远程连接
3.1 进入docker容器
$ sudo docker exec -it mysql /bin/bash 3.2 进入mysql,密码:123456
$ mysql -uroot -p 3.3 查询远程连接的用户配置
> select user,password,host from mysql.user; 3.4 修改权限:%代表允许所有IP访问,your_password修改为自己的密码
> grant all privileges on *.* to root@"%" identified by "your_password"; 3.5 刷新权限
> flush privileges;

安装Nginx

1. 拉取镜像
$ sudo docker pull nginx 2. 运行基础镜像
$ sudo docker run --name nginx -d nginx 3. 把配置目录/etc/nginx复制到共享卷目录
$ sudo mkdir -p /srv/nginx
$ sudo docker cp nginx:/etc/nginx/ /srv/nginx/conf 4. 删除原有镜像
$ sudo docker stop nginx
$ sudo docker rm nginx 5. 重新运行镜像
$ sudo docker run --name nginx -p 80:80 --volume /srv/nginx/conf:/etc/nginx/:Z --volume /srv/nginx/html:/usr/share/nginx/html:Z --volume /srv/nginx/logs:/var/log/nginx:Z --detach nginx

安装Jenkins

1. 拉取镜像
$ sudo docker pull jenkins/jenkins:lts 2. 创建volume文件夹
$ sudo mkdir -p /srv/jenkins 3. 修改volume文件夹权限(不建议添加参数:--privileged=true)
$ sudo chown -R 1000:1000 /srv/jenkins/ 4. 运行Docker,其中的":Z"是为了防止由于Selinux权限导致的问题
$ sudo docker run --name="jenkins" --publish 8080:8080 --publish 50000:50000 --volume /srv/jenkins:/var/jenkins_home:Z --restart=always --detach docker.io/jenkins/jenkins:lts 5. 修改/srv/jenkins/hudson.model.UpdateCenter.xml的url为:
# 原来为:http://updates.jenkins-ci.org/update-center.json
https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json 6. 进入${ip}:8080,如果一直卡在等待页面,提示:显示正在启动,请稍后...。原因是有一个connectionCheckUrl指向了google的网址,由于环境原因,导致一直无法访问,导致一直等待 7. 解决方法:修改/srv/jenkins/updates/default.json,修改为:
# 原来为:http://www.google.com/
"connectionCheckUrl":"https://www.baidu.com/" 8. 如果没有发现updates文件夹,需要先进入jenkins的等待页面,稍等片刻。updates文件夹会出现 9. 至此,Jenkins安装完成,重启jenkins
$ sudo docker restart jenkins 10. 更新设置开机启动、失败自动重启:
$ sudo docker update --restart=always ${CONTAINER ID} 11. 进入Jenkins中,发现下载插件时会失败,解决方案如下: 11.1 安装nginx,参考:安装Nginx 11.2 添加host映射:
$ sudo echo "127.0.0.1 updates.jenkins-ci.org" >> /etc/hosts 11.3 添加nginx配置:
$ sudo vi /srv/nginx/conf/conf.d/jenkins.conf 11.4 添加以下内容:
server {
listen 80;
server_name localhost; rewrite ^/download/plugins/(.*)$ https://mirrors.tuna.tsinghua.edu.cn/jenkins/plugins/$1? last; location /download/plugins
{
proxy_next_upstream http_502 http_504 error timeout invalid_header;
proxy_set_header Host mirrors.tuna.tsinghua.edu.cn;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
rewrite /download/plugins(.*) /jenkins/plugins/$1 break;
proxy_pass https://mirrors.tuna.tsinghua.edu.cn;
}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
} 14. 再次下载插件,就不会失败,如有其他报错,可参考类似的方法,把地址映射到https://mirrors.tuna.tsinghua.edu.cn/jenkins/plugins 15. 完成Jenkins安装及配置

安装Gitlab

1. 拉取镜像
$ sudo docker pull gitlab/gitlab-ee 2. 运行镜像
$ sudo docker run --name gitlab --hostname gitlab.demo.com --publish 6443:443 --publish 680:80 --publish 622:22 --volume /srv/gitlab/config:/etc/gitlab:Z --volume /srv/gitlab/logs:/var/log/gitlab:Z --volume /srv/gitlab/data:/var/opt/gitlab:Z --detach --restart always docker.io/gitlab/gitlab-ee:latest 3. 如果进入首页,报错502,可能是内存不足导致,gitlab要求内存大于2G,可通过虚拟内存解决,但会很卡,下面给出设置虚拟内存命令:
$ sudo dd if=/dev/zero of=/var/swap bs=1024 count=2048000 ; mkswap /var/swap ; swapon /var/swap ; free -h

Docker安装MongoDB、MySQL、Jenkins、Gitlab、Nginx的更多相关文章

  1. Docker 安装 mongoDB(五)

    Docker 安装 mongoDB 1.搜索docker镜像(可以看到搜索的结果,这个结果是按照一定的星级评价规则排序的) docker search mongo 2.拉取docker的mongo镜像 ...

  2. Linux平台安装MongoDB及使用Docker安装MongoDB

    一.Linux平台安装MongoDB MongoDB 提供了 linux 各发行版本 64 位的安装包,你可以在官网下载安装包. 下载地址:https://www.mongodb.com/downlo ...

  3. docker 安装完mysql 后客户端无法访问

    1.在虚拟机的centos 中安装 docker 的mysql 镜像. docker run --name mysql01 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=12 ...

  4. Docker01 centos系统安装、centos安装docker、docker安装mongoDB

    1 centos系统安装 本博文是基于 centos6.5 的,利用VMware 虚拟机搭建 centos6.5 系统 1.1 centos6.5资源获取 1.2 安装 1.2.1 新建虚拟机 1.2 ...

  5. MongoDB学习笔记二:使用Docker安装MongoDB

    目录 Docker安装MongoDB Docker给MongoDB设置用户密码 NoSQL Manager for MongoDB连接 为admin赋权限 上一个笔记介绍了Windows下安装Mong ...

  6. yum 安装mongodb mysql

    // 云环境下更新包 (center os)yum update (多更有益) 修改yum包管理配置:vi /etc/yum.repos.d/mongodb-org-3.4.repo // 会自动新建 ...

  7. mac系统下docker安装配置mysql详细步骤

    上文介绍了MacOS安装Docker傻瓜式教程,安装好后第一件事就决定把本地数据库迁移过来,那么首先就得安装mysql,下面就开始我们的安装之旅吧. 一.docker配置镜像加速器 我们使用docke ...

  8. docker安装mongodb和redis

    一.安装mongodb docker pull mongo docker run -p 27017:27017 -d --name mongodb01 mongo docker run -p 2701 ...

  9. Docker安装配置mysql

    Docker安装mysql踩坑日记 拉取镜像 sudo docker pull mysql:5.7 运行镜像 docker run -p 3306:3306 --name mysql -v /myda ...

随机推荐

  1. 攻防世界——Misc新手练习区解题总结<3>(9-10题)

    第九题SimpleRAR: 下载附件后得到一个压缩包打开后得到如下提示 文件头损坏,让我们打开winhex看一下 7a为子块而文件头为74,这里将7a改为74(这里我也不是很清楚,详细大家可以自行去查 ...

  2. mac android 真机调试

    1.已经安装好Androidstudio或者eclipse 2.下载配置好Android Sdk等 3.将android手机通过USB数据线连接Mac,打开终端输入system_profiler SP ...

  3. 使用easyexcel时遇到Could not initialize class net.sf.cglib.beans.BeanMap$Generator

    可以访问 这里 查看更多关于大数据平台建设的原创文章. 上一篇文章 Maven项目为什么会产生NoClassDefFoundError的jar包冲突 结合了大量的图解,详细介绍了Maven项目产生ja ...

  4. 6 年前,只会 JSP 和 Servlet 就可以找到工作

    这篇文章在去年就已经构思了,不过一直都没有整理出来,今天终于完成了这篇文章,所以发上来给大家看一看,都是一些个人的小感慨,我的观点可能不是非常的完善,大家也可以一起讨论. 找工作之难,难于上青天 五六 ...

  5. 存储过程中拼接SQL语句

    很多时候我们需要利用参数在存储过程中重新组织SQL语句,在存储过程中拼接的SQL语句只是一个字符串,不会被直接执行,所以加一个execute执行它就可以了.具体看如下演示代码: 代码: set ANS ...

  6. vue-cli3项目配置eslint代码规范

    前言 最近接手了一个项目,由于之前为了快速开发,没有做代码检查.为了使得代码更加规范以及更易读,所以就要eslint上场了. 安装依赖 安装依赖有两种方法: 1. 在cmd中打上把相应的依赖加到dev ...

  7. leetcode刷题-56合并区间

    题目 给出一个区间的集合,请合并所有重叠的区间. 示例 1: 输入: [[1,3],[2,6],[8,10],[15,18]]输出: [[1,6],[8,10],[15,18]] 思路 通过设置一个移 ...

  8. JS -- DOM(文档对象模型)

    认识DOM(文档对象模型) DOM(Document Object Model):定义访问和处理HTML文档的标准方法. DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). < ...

  9. CTF-WeChall-第二天

    2020.09.10 奥力给,举步维艰的时候就是要一边做一遍记,虽然慢但是不要嫌弃,要不然就是举步不前

  10. ASP.NET Core 配置与获取

    目录 1,来自字典 2,来自配置文件 3,层次结构 4,映射 ASP.NET Core 中,可以使用 ConfigurationBuilder 对象来构建. 主要分为三部:配置数据源 -> Co ...