ホームページ  >  記事  >  データベース  >  docker に mysql をインストールして実行する方法

docker に mysql をインストールして実行する方法

王林
王林転載
2023-05-30 11:58:062010ブラウズ

ps: 実験環境は次のとおりです: ubuntu 14.04、64 ビット

1. mysql イメージを取得します

docker Hub ウェアハウス mysql イメージを取得します

sudo docker pull mysql

イメージを表示

sudo docker images

mysql latest 18f13d72f7f0 2 weeks ago 383.4 mb

2. mysql を実行しますコンテナ

mysql インスタンスを実行するコマンドは次のとおりです:

コードをコピーします コードは次のとおりです:

sudo docker run --name first-mysql -p 3306:3306 -e mysql \_root\_password=123456 -d mysql

5b6bf6f629bfe46b4c8786b555d8db1947680138b2de1f268f310a15ced7247a

上記のコマンドの各パラメータの意味: -name の後に名前が続きますこの画像の

-p 3306:3306 は、ローカル マシンにマッピングされているポート番号が 3306 ポート (2 番目) であることを意味し、このコンテナ内のポートも 3306 (1 番目のもの) であることを意味します。

-d は、デーモン プロセスが 3306 であることを意味します。は実行に使用されます。つまり、サービスがハングします。 バックグラウンドで


#現在実行中のコンテナーのステータスを表示します。

コードをコピーします。コードは次のとおりです。

sudo docker ps

コンテナ ID イメージ コマンド作成ステータス ポート名5b6bf6f629bf

mysql "docker-entrypoint.sh" 32 時間前から 5 時間まで 0.0.0.0:3306->3306/ tcp first-mysql

mysql データベースにアクセスするには、mysql クライアントをマシンにインストールする必要があります。

sudo apt-get install mysql-client-core-5.6

<br> 次に、mysql コマンドを使用してサーバーにアクセスします。パスワードは 123456,192.168 です。今示されているように、.95.4 は私のマシンの IP です。3306 は、今示されているように、この物理マシンが占有しているポートです (Docker 内のポートではありません)

mysql -h192.168.95.4 - p3306 -uroot -p123456

アクセスの結果は次のとおりです:

mysql> show databases;

+--------------------+
| database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+

4 rows in set (0.00 sec)

3. 2 番目の mysql インスタンスを実行します


使用 docker が仮想マシンと比較される理由は、docker が消費するリソースが非常に少なく、多くの分離された環境を「開く」ことができるためです。そのため、引き続き 2 番目の mysql インスタンスを実行し、前のイメージを使用します。名前は Second-mysql です。

コードをコピーします。コードは次のとおりです。

sudo docker run --name Second-mysql -p 3306:3307 -e mysql\_root\_password=123456 -d

mysql2de4ddb5bfb9b9434af8e72368631e7f4c3f83ee354157328049d 7d0

f5523661docker: デーモンからのエラー応答: ドライバーはエンドポイント Second-mysql での外部接続のプログラミングに失敗しました (33aa29d891a1cb540de250bcbbbe9a0a41cd98) f61a4e9f129a2ad5db69da4984): 0.0.0.0:3306 のバインドに失敗しました: ポートはすでに割り当てられています。

検証用最初の1 つはこのマシンのポート番号で、ポート 3306 はまだ使用されています。その後、作成は上記のようになります。エラーが発生しましたが、コンテナ ID が生成されました。ポートを変更すると、名前が競合するためエラーが報告されます。つまり、今回は作成に失敗しました。この名前は占有されます:

コードをコピーします コードは次のとおりです:

sudo docker run --name Second-mysql -p 3307:3306 -e mysql\_root\_password=123456 -d

mysqldocker: デーモンからのエラー応答: 競合。名前「/second-mysql」はコンテナ 2de4ddb5bfb9b9434af8e72368631e7f4c3f83ee354157328049d7d0f5523661.

を削除する必要があります。または名前を変更します)そのコンテナがその名前を再利用できるようにするため..

2 番目の mysql コンテナがまだ docker プロセス内にあることを確認するために、ps -a コマンドを使用します。 -mysql は 34 分間稼働しており、34 分間動作しており、2 番目の -mysql が作成されたばかりであることを示しています。

sudo docker ps -a

container id    image        command         created       status       ports          names
2de4ddb5bfb9    mysql        "docker-entrypoint.sh"  about a minute ago  created                   second-mysql
5b6bf6f629bf    mysql        "docker-entrypoint.sh"  34 minutes ago    up 34 minutes    0.0.0.0:3306->3306/tcp  first-mysql

次のコマンドに示すように、rm コマンドを使用してこのコンテナを削除します。

maintain@maintain-dev1:~$ sudo docker rm second-mysql

maintain@maintain-dev1:~$ sudo docker ps -a

container id image command created status ports names
5b6bf6f629bf mysql "docker-entrypoint.sh" 42 minutes ago up 42 minutes 0.0.0.0:3306->3306/tcp first-mysql

2 番目の mysql コンテナを再確立し、物理マシンの 3307 ポートを占有します。 ##
sudo docker run --name second-mysql -p 3307:3306 -e mysql\_root\_password=123456 -d mysql

5404fb11f29cba07b991f34056d6b40ed0888aa905a45e637e396d071bd7f331

sudo docker ps

container id    image        command         created       status       ports          names
5404fb11f29c    mysql        "docker-entrypoint.sh"  12 seconds ago   up 11 seconds    0.0.0.0:3307->3306/tcp  second-mysql
5b6bf6f629bf    mysql        "docker-entrypoint.sh"  43 minutes ago   up 43 minutes    0.0.0.0:3306->3306/tcp  first-mysql

上図に示すように、両方のインスタンスが正常に実行されているため、2 番目のコンテナにアクセスするために、ポート 3307 を指定して mysql クライアントにログインします。

mysql -h192.168.95.4 -p3307 -uroot -p123456

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 2
server version: 5.7.15 mysql community server (gpl)
copyright (c) 2000, 2016, oracle and/or its affiliates. all rights reserved.
oracle is a registered trademark of oracle corporation and/or itsaffiliates. other names may be trademarks of their respectiveowners.
type &#39;help;&#39; or &#39;\h&#39; for help. type &#39;\c&#39; to clear the current input statement.

4.jdbc test (maven & spring boot)

ソース例:
Java Spring を使用してデータベースを操作します。 Spring 公式 Web サイトの例では、hibernate や myibatis を使用せずに、ネイキッド SQL メソッドである jdbctemplate を使用しています。

Spring 公式 Web サイトの例では、構成を生成する手間をかけずに、組み込みメモリ データベースである h2 を使用しています。ファイルをオブジェクトとして、

xml の代わりに yaml を練習するために、次の mysql jdbc 設定、application.yaml.

### application.yaml
### mysql config
spring:
 datasource:
  dbcp:
   driver-class-name: com.mysql.jdbc.driver
   url: jdbc:mysql://192.168.18.129:3306/test1
   username: root
   password: 123456

を使用しました。自動依存関係注入を探すのに長い時間を費やしました。 jdbctemplate オブジェクトですが、取得できませんでした。次のようなものでした。同様に、最初にデータソースを自分で生成し、次に新しい jdbctemlate オブジェクトを作成し、最後に jdbctemplate を使用してデータベースを操作します。これは非常に醜いですが、アドバイスをいただければ幸いです。

@bean
@configurationproperties(prefix = "spring.datasource.dbcp")
public datasource mysqlsource() { 
  return datasourcebuilder.create().build();
}
@bean
public jdbctemplate mysqljdbctemplate() { 
  return new jdbctemplate(mysqlsource());
}

以下は、jdk8 の関数型プログラミングを使用した、データベースに対するいくつかのひどい操作です:

jdbctemplate jdbctemplate = mysqljdbctemplate();
jdbctemplate.execute("drop table if exists customers");
jdbctemplate.execute("create table customers(" + "id serial, first_name varchar(255), last_name varchar(255))");
// split up the array of whole names into an array of first/last names
list<object[]> splitupnames = arrays.aslist("john woo", "jeff dean", "josh bloch", "josh long")
 .stream() .map(name -> name.split(" ")) .collect(collectors.tolist());
// use a java 8 stream to print out each tuple of the list
splitupnames.foreach(name -> log.info(string.format("inserting customer record for %s %s", name[0], name[1])));
// uses jdbctemplate&#39;s batchupdate operation to bulk load data
jdbctemplate.batchupdate("insert into customers(first_name, last_name) values (?,?)", splitupnames);
log.info("querying for customer records where first_name = &#39;josh&#39;:");
jdbctemplate.query( 
  "select id, first_name, last_name from customers where first_name = ?", 
  new object[]{"josh"}, (rs, rownum) -> new customer(rs.getlong("id"), rs.getstring("first_name"), rs.getstring("last_name")))
  .foreach(customer -> log.info(customer.tostring()));

以下は、mysql クライアントで検証されます:

mysql> select * from customers;
+----+------------+-----------+
| id | first_name | last_name |
+----+------------+-----------+
| 1 | john    | woo    |
| 2 | jeff    | dean   |
| 3 | josh    | bloch   |
| 4 | josh    | long   |
+----+------------+-----------+

4 rows in set (0.00 sec)

5いくつかの落とし穴が発生しました

maven 構成

jdk8 のラムダ式が使用されており、java.version は maven で構成する必要があります

<properties> 
<java.version>1.8</java.version>
</properties>

docker service restart

Docker サービスがハングすると、コンテナもハングし、再起動しません。コンテナの実行時に --restart=always パラメータを指定する必要があります

以上がdocker に mysql をインストールして実行する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はyisu.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。