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 イメージ コマンド作成ステータス ポート名5b6bf6f629bfmysql "docker-entrypoint.sh" 32 時間前から 5 時間まで 0.0.0.0:3306->3306/ tcp first-mysqlmysql データベースにアクセスするには、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 です。
f5523661docker: デーモンからのエラー応答: ドライバーはエンドポイント Second-mysql での外部接続のプログラミングに失敗しました (33aa29d891a1cb540de250bcbbbe9a0a41cd98) f61a4e9f129a2ad5db69da4984): 0.0.0.0:3306 のバインドに失敗しました: ポートはすでに割り当てられています。
検証用最初の1 つはこのマシンのポート番号で、ポート 3306 はまだ使用されています。その後、作成は上記のようになります。エラーが発生しましたが、コンテナ ID が生成されました。ポートを変更すると、名前が競合するためエラーが報告されます。つまり、今回は作成に失敗しました。この名前は占有されます:
を削除する必要があります。または名前を変更します)そのコンテナがその名前を再利用できるようにするため..
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
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
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 'help;' or '\h' for help. type '\c' to clear the current input statement.
ソース例:
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'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 = 'josh':"); 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)
maven 構成
<properties> <java.version>1.8</java.version> </properties>
以上がdocker に mysql をインストールして実行する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。