国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

.NET Core+MySql+Nginx 容器化部署

jerry / 3087人閱讀

摘要:容器化容器化之多容器應(yīng)用部署容器化部署引言上兩節(jié)我們通過簡單的學(xué)習(xí)了的基本操作。基于當(dāng)前項(xiàng)目構(gòu)建的容器服務(wù),依賴于服務(wù)。最后,使用綜合完成了容器化部署。參考資料容器化容器化之多容器應(yīng)用部署

.NET Core容器化@Docker
.NET Core容器化之多容器應(yīng)用部署@Docker-Compose
.NET Core+MySql+Nginx 容器化部署
GitHub-Demo:Docker.NetCore.MySql
1. 引言

上兩節(jié)我們通過簡單的demo學(xué)習(xí)了docker的基本操作。這一節(jié)我們來一個(gè)進(jìn)階學(xué)習(xí),完成ASP.NET Core + MySql + Nginx的容器化部署。

本文是基于CentOS 7.4環(huán)境進(jìn)行演示,示例項(xiàng)目可以訪問Docker.NetCore.MySql進(jìn)行下載。

2. Hello MySQL

同樣我們還是以循序漸進(jìn)的方式來展開。首先來基于Docker來試玩一下MySQL。

2.1. 創(chuàng)建MySql實(shí)例
//拉取mysql鏡像
 docker pull mysql
$ docker images$
REPOSITORY                           TAG                 IMAGE ID            CREATED             SIZE
docker.io/mysql                      latest              7d83a47ab2d2        13 days ago         408.2 MB
//創(chuàng)建一個(gè)mysql實(shí)例
$ docker run --name hello.mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql
$ docker ps 
CONTAINER ID        IMAGE      COMMAND                  CREATED             STATUS              PORTS          NAMES
e21bbd84e0b5        mysql      "docker-entrypoint.sh"   3 minutes ago       Up 3 minutes        3306/tcp        hello.mysql

下面我們直接在容器中連接到我們剛剛創(chuàng)建的mysql數(shù)據(jù)庫:

$ docker exec -it hello.mysql 
> mysql -uroot -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or g.
Your MySQL connection id is 8
Server version: 5.7.20 MySQL Community Server (GPL)

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type "help;" or "h" for help. Type "c" to clear the current input statement.

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.00 sec)
2.2. 掛載數(shù)據(jù)卷

上面創(chuàng)建的mysql實(shí)例其數(shù)據(jù)都在容器內(nèi)部存儲,這樣就暴露了一個(gè)問題,如果容器銷毀,那么對應(yīng)的數(shù)據(jù)庫數(shù)據(jù)就會丟失。那如何持久化存儲容器內(nèi)數(shù)據(jù)呢?我們可以通過掛載數(shù)據(jù)卷的方式來解決這一問題。

//創(chuàng)建數(shù)據(jù)卷
$ docker volume create --name hello.db
hello.db
//查看數(shù)據(jù)卷信息
$ docker volume inspect hello.db
[
    {
        "Name": "hello.db",
        "Driver": "local",
        "Mountpoint": "/var/lib/docker/volumes/hello.db/_data",
        "Labels": {},
        "Scope": "local"
    }
]
// 掛載數(shù)據(jù)卷啟動MySql實(shí)例
$ docker run --name hello.mysql 
> -v hello.db:/var/lib/mysql 
> -e MYSQL_ROOT_PASSWORD=123456 -d mysql

上面是使用使用了docker volume create命令創(chuàng)建了一個(gè)數(shù)據(jù)卷,當(dāng)然我們也可以自行掛載某個(gè)目錄作為數(shù)據(jù)卷。

3. 準(zhǔn)備.NET Core+EFCore+MySql項(xiàng)目

為了演示方便,我準(zhǔn)備了一個(gè)ASP.NET Core+EFCore+MySql的示例項(xiàng)目。其結(jié)構(gòu)如下所示:

是基于.NET Core Mvc模板項(xiàng)目,其中定義了一個(gè)Product實(shí)體,并通過ProductsController暴露WebApi接口。核心代碼如下:

Product實(shí)體類:

public class Product
{
    public int ProductId { get; set; }
    public string Name { get; set; }
    public decimal Price { get; set; }
    public int StockQty { get; set; }
}

DbContext類:

public class MySqlDbContext : DbContext
{
    public MySqlDbContext (DbContextOptions options)
        : base(options)
    {
    }

    public DbSet Products { get; set; }
}

數(shù)據(jù)庫初始化類:

public class DbInitializer
{
    public static void Initialize(MySqlDbContext context)
    {
        context.Database.EnsureCreated();

        if (context.Products.Any())
        {
            return;
        }

        var products = new Product[]
        {
            new Product{Name="iphone 6",Price=5000,StockQty=10 },
            new Product{Name="iphone 7",Price=6000,StockQty=10 },
            new Product{Name="iphone 7 plus",Price=7000,StockQty=10 },
            new Product{Name="iphone x",Price=8000,StockQty=10 }
        };

        context.Products.AddRange(products);

        context.SaveChanges();
    }
}

該數(shù)據(jù)庫初始化類會在項(xiàng)目啟動時(shí)運(yùn)行。詳細(xì)代碼可參考Docker.NetCore.MySql

4. 基于示例項(xiàng)目進(jìn)行實(shí)操演練 4.1 安裝Git并Clone示例項(xiàng)目
$ yum install git
$ git --version
git version 1.8.3.1
$ cd ~/demo
$ git clone https://github.com/yanshengjie/Docker.NetCore.MySql.git
Cloning into "Docker.NetCore.MySql"...
remote: Counting objects: 155, done.
remote: Compressing objects: 100% (125/125), done.
remote: Total 155 (delta 42), reused 123 (delta 25), pack-reused 0
Receiving objects: 100% (155/155), 534.30 KiB | 333.00 KiB/s, done.
Resolving deltas: 100% (42/42), done.
4.2. 構(gòu)建鏡像

細(xì)心的你會發(fā)現(xiàn),項(xiàng)目中已經(jīng)定義了Dockerfile,所以我們可以直接使用docker build構(gòu)建鏡像。

# cd Docker.NetCore.MySql
[root@iZ288a3qazlZ Docker.NetCore.MySql]# ls
appsettings.Development.json  docker-compose.yml           Program.cs             Views
appsettings.json              Dockerfile                   proxy.conf             wwwroot
bundleconfig.json             Docker.NetCore.MySql.csproj  README.md
Controllers                   LICENSE                      ScaffoldingReadMe.txt
Data                          Models                       Startup.cs
//構(gòu)建鏡像
# docker build -t docker.netcore.mysql .
Sending build context to Docker daemon 3.045 MB
Step 1 : FROM microsoft/dotnet:latest
 ---> 7d4dc5c258eb
Step 2 : WORKDIR /app
 ---> Using cache
 ---> 98d48a4e278c
Step 3 : COPY . /app
 ---> 6b1bf8bb5261
Removing intermediate container b86460477977
Step 4 : RUN dotnet restore
 ---> Running in 4e0a46f762bb
  Restoring packages for /app/Docker.NetCore.MySql.csproj...
  Installing Microsoft.CodeAnalysis.Razor 2.0.0.
  .....
  Restore completed in 216.83 ms for /app/Docker.NetCore.MySql.csproj.
 ---> 4df70c77916e
Removing intermediate container 4e0a46f762bb
Step 5 : EXPOSE 5000
 ---> Running in 11b421b3bd3e
 ---> 3506253060fe
Removing intermediate container 11b421b3bd3e
Step 6 : ENV ASPNETCORE_URLS http://*:5000
 ---> Running in 201aabbab72c
 ---> 7f29963a8d96
Removing intermediate container 201aabbab72c
Step 7 : ENTRYPOINT dotnet run
 ---> Running in c79f73cba162
 ---> 9d1fb6ee46cb
Removing intermediate container c79f73cba162
Successfully built 9d1fb6ee46cb
[root@iZ288a3qazlZ Docker.NetCore.MySql]# docker images docker.netcore.mysql
REPOSITORY             TAG                 IMAGE ID            CREATED             SIZE
docker.netcore.mysql   latest              9d1fb6ee46cb        13 seconds ago      1.756 GB
4.3. 啟動鏡像并連接到指定數(shù)據(jù)庫

docker提供了--link參數(shù)用于在容器之間建立連接。下面我們實(shí)例化創(chuàng)建的鏡像docker.netcore.mysql并命名容器名為hello.netcore.mysql,并使用--link參數(shù)與我們文章開頭建立的hello.mysql容器建立連接。

# docker run --name hello.netcore.mysql --link hello.mysql:db -d -p 5000:5000 
docker.netcore.mysql
這里需要特別注意一下--link=hello.mysql:db,這個(gè)參數(shù)就是告訴Docker容器需要使用hello.mysql容器,并將其別名命名為db,這樣在hello.netcore.mysql這個(gè)容器中就可以使用db來作為提供mysql數(shù)據(jù)庫服務(wù)的服務(wù)器。這也就是為什么我們.NET Core項(xiàng)目中連接字符串設(shè)置為server=db;的原因。
` "ConnectionStrings": {
"MySql": "server=db;database=MySqlDbContext;uid=root;pwd=123456;"

}`

//查看運(yùn)行中容器列表
# docker ps 
CONTAINER ID        IMAGE                  COMMAND                  CREATED             STATUS              PORTS                    NAMES
5cbfd27ebe2a        docker.netcore.mysql   "dotnet run"             2 minutes ago       Up 2 minutes        0.0.0.0:5000->5000/tcp   hello.netcore.mysql
4dfa4159b669        mysql                  "docker-entrypoint.sh"   About an hour ago   Up About an hour    3306/tcp                 hello.mysql
//訪問api/products
[root@iZ288a3qazlZ Docker.NetCore.MySql]# curl http://localhost:5000/api/products
[{"productId":1,"name":"iphone 6","price":5000.0000000000000000000000000,"stockQty":10},{"productId":2,"name":"iphone 7","price":6000.0000000000000000000000000,"stockQty":10},{"productId":3,"name":"iphone 7 plus","price":7000.0000000000000000000000000,"stockQty":10},{"productId":4,"name":"iphone x","price":8000.000000000000000000000000,"stockQty":10}]

從上圖可知,我們完成了.NET Core與MySql的連接。

5. ASP.NET Core + MySql + Nginx

結(jié)合上一篇文章.NET Core容器化之多容器應(yīng)用部署@Docker-Compose,我們來使用docker-compose完成asp.net core + mysql + nginx的多容器部署。

5.1. 定義 docker-compose.yml
version: "2"
services:
  db:
    container_name: hello.db
    environment:
      MYSQL_ROOT_PASSWORD: 123456
  volumes:
    - ./mysql:/var/lib/mysql

  web:
    container_name: hello.web
    build: .
    depends_on:
      - db
    links:
      - db
  
  reverse-proxy:
    container_name: hello.proxy
    image: nginx
    depends_on:
      - web
    ports:
      - "9090:8080"
    volumes:
      - ./proxy.conf:/etc/nginx/conf.d/default.conf

其中定義了三個(gè)服務(wù):

db:使用mysql鏡像,并掛載當(dāng)前項(xiàng)目下的mysql文件夾來持久化存儲。

web:基于當(dāng)前項(xiàng)目構(gòu)建的容器服務(wù),依賴于db服務(wù)。

reverse-proxy:使用nginx定義反向代理服務(wù),其中掛載了當(dāng)前項(xiàng)目下的proxy.conf文件作為反向代理配置文件。其中proxy.conf的配置如下(注意proxy_pass指定的url為http://web:5000):

server {
    listen 8080;

    location / {
        proxy_pass http://web:5000;
    }
}
5.2. 啟動Compose

在啟動Compose之前,建議清空上面創(chuàng)建的容器。也可以使用docker rm $(docker ps -qa)清除所有容器。

//啟動compose
[root@iZ288a3qazlZ Docker.NetCore.MySql]# docker-compose up -d
Creating network "dockernetcoremysql_default" with the default driver
Building web
Step 1 : FROM microsoft/dotnet:latest
 ---> 7d4dc5c258eb
Step 2 : WORKDIR /app
 ---> Using cache
 ---> 98d48a4e278c
Step 3 : COPY . /app
 ---> d41b32323c0f
Removing intermediate container 1259f5fb82bc
Step 4 : RUN dotnet restore
 ---> Running in d482e355de77
  Restoring packages for /app/Docker.NetCore.MySql.csproj...
  Installing Microsoft.CodeAnalysis.Razor 2.0.0.
  .....
  Restore completed in 216.83 ms for /app/Docker.NetCore.MySql.csproj.
 ---> a0658008f161
Removing intermediate container d482e355de77
Step 5 : EXPOSE 5000
 ---> Running in dc6eeb29fd5e
 ---> a419314ece08
Removing intermediate container dc6eeb29fd5e
Step 6 : ENV ASPNETCORE_URLS http://*:5000
 ---> Running in c1d1474b14a0
 ---> 9cc13c549042
Removing intermediate container c1d1474b14a0
Step 7 : ENTRYPOINT dotnet run
 ---> Running in efdf0e857a84
 ---> 830ac11428cf
Removing intermediate container efdf0e857a84
Successfully built 830ac11428cf
Creating hello.db ... done
Creating hello.web ... done
Creating hello.proxy ... done
Creating hello.web ...
Creating hello.proxy ...
[root@iZ288a3qazlZ Docker.NetCore.MySql]# docker ps
CONTAINER ID        IMAGE                    COMMAND                  CREATED             STATUS              PORTS                            NAMES
6253bf85682e        nginx                    "nginx -g "daemon off"   33 seconds ago      Up 28 seconds       80/tcp, 0.0.0.0:9090->8080/tcp   hello.proxy
ea553a9e22f2        dockernetcoremysql_web   "dotnet run"             37 seconds ago      Up 32 seconds       5000/tcp                         hello.web
a1f5aa981bfb        mysql                    "docker-entrypoint.sh"   38 seconds ago      Up 36 seconds       3306/tcp                         hello.db
[root@iZ288a3qazlZ Docker.NetCore.MySql]# docker-compose ps
   Name                 Command             State               Ports
----------------------------------------------------------------------------------
hello.db      docker-entrypoint.sh mysqld   Up      3306/tcp
hello.proxy   nginx -g daemon off;          Up      80/tcp, 0.0.0.0:9090->8080/tcp
hello.web     dotnet run                    Up      5000/tcp
[root@iZ288a3qazlZ Docker.NetCore.MySql]# curl http://localhost:9090/api/products
[{"productId":1,"name":"iphone 6","price":5000.0000000000000000000000000,"stockQty":10},{"productId":2,"name":"iphone 7","price":6000.0000000000000000000000000,"stockQty":10},{"productId":3,"name":"iphone 7 plus","price":7000.0000000000000000000000000,"stockQty":10},{"productId":4,"name":"iphone x","price":8000.000000000000000000000000,"stockQty":10}]

上面的運(yùn)行結(jié)果顯示,我們已經(jīng)成功完成了ASP.NET Core+MySql+Nginx的多容器應(yīng)用部署。通過瀏覽器訪問http::9090/api/products即可訪問我們暴露的api。

5.3. 數(shù)據(jù)庫驗(yàn)證

我們來驗(yàn)證一下數(shù)據(jù)庫是否成功創(chuàng)建:

[root@iZ288a3qazlZ Docker.NetCore.MySql]# ls mysql
auto.cnf         client-key.pem         ib_logfile0  performance_schema  server-key.pem
ca-key.pem       MySqlDbContext  ib_logfile1  private_key.pem     sys
ca.pem           ib_buffer_pool         ibtmp1       public_key.pem
client-cert.pem  ibdata1                mysql        server-cert.pem
[root@iZ288a3qazlZ Docker.NetCore.MySql]# docker exec -it hello.db mysql -uroot -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or g.
Your MySQL connection id is 8
Server version: 5.7.20 MySQL Community Server (GPL)

Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type "help;" or "h" for help. Type "c" to clear the current input statement.
mysql> show databases;
+-----------------------+
| Database              |
+-----------------------+
| information_schema    |
| MySqlDbContext  |
| mysql                 |
| performance_schema    |
| sys                   |
+-----------------------+
5 rows in set (0.00 sec)

mysql> use MySqlDbContext;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;
+---------------------------------+
| Tables_in_MySqlDbContext |
+---------------------------------+
| Products                        |
+---------------------------------+
1 row in set (0.00 sec)

mysql> select * from Products;
+-----------+---------------+-------------------------------------+----------+
| ProductId | Name          | Price                               | StockQty |
+-----------+---------------+-------------------------------------+----------+
|         1 | iphone 6      | 5000.000000000000000000000000000000 |       10 |
|         2 | iphone 7      | 6000.000000000000000000000000000000 |       10 |
|         3 | iphone 7 plus | 7000.000000000000000000000000000000 |       10 |
|         4 | iphone x      | 8000.000000000000000000000000000000 |       10 |
+-----------+---------------+-------------------------------------+----------+
4 rows in set (0.00 sec)

從上面的運(yùn)行結(jié)果可知,我們成功將項(xiàng)目文件夾下的mysql文件夾掛載到容器內(nèi)部進(jìn)行數(shù)據(jù)持久化。

6. 最后

本文通過先介紹如何基于Docker實(shí)例化MySQL容器,再介紹如何通過掛載數(shù)據(jù)卷來持久化MySQL數(shù)據(jù),以及如何使用--Link參數(shù)進(jìn)行容器之間的連接,完成了.NET?Core連接MySQL數(shù)據(jù)庫。
最后,使用Docker-Compose綜合ASP.NET?Core+MySQL+Nginx完成了容器化部署。

下一節(jié)我們來介紹下如何使用Docker-Swarm進(jìn)行集群部署。

7. 參考資料

mysql -Docker Documentation
Hello Docker
.NET Core容器化@Docker
.NET Core容器化之多容器應(yīng)用部署@Docker-Compose

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/27186.html

相關(guān)文章

  • .NET Core+MySql+Nginx 容器部署

    摘要:容器化容器化之多容器應(yīng)用部署容器化部署引言上兩節(jié)我們通過簡單的學(xué)習(xí)了的基本操作。基于當(dāng)前項(xiàng)目構(gòu)建的容器服務(wù),依賴于服務(wù)。最后,使用綜合完成了容器化部署。參考資料容器化容器化之多容器應(yīng)用部署 showImg(https://segmentfault.com/img/remote/1460000012801559); .NET Core容器化@Docker.NET Core容器化之多容器...

    ybak 評論0 收藏0
  • Nginx+Docker部署模式下 asp.net core 獲取真實(shí)的客戶端ip

    摘要:結(jié)論使用獲取客戶端不會自動取中的值需求單獨(dú)處理。參考資料負(fù)載均衡的場景下如何獲取客戶端地址 [toc] 場景 線上環(huán)境使用Nginx(安裝在宿主機(jī))+Docker進(jìn)行部署,應(yīng)用獲取客戶端ip地址不正確,獲取客戶端IP的代碼為Request.HttpContext.Connection.RemoteIpAddress.MapToIPv4() 過程還原 搭建一個(gè)webapi示例環(huán)境 創(chuàng)建一...

    ermaoL 評論0 收藏0
  • Nginx+Docker部署模式下 asp.net core 獲取真實(shí)的客戶端ip

    摘要:結(jié)論使用獲取客戶端不會自動取中的值需求單獨(dú)處理。參考資料負(fù)載均衡的場景下如何獲取客戶端地址 [toc] 場景 線上環(huán)境使用Nginx(安裝在宿主機(jī))+Docker進(jìn)行部署,應(yīng)用獲取客戶端ip地址不正確,獲取客戶端IP的代碼為Request.HttpContext.Connection.RemoteIpAddress.MapToIPv4() 過程還原 搭建一個(gè)webapi示例環(huán)境 創(chuàng)建一...

    Kyxy 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<