質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

1回答

1321閲覧

AWSのMysqlのユーザー登録を効率よく実行する方法

1nakaji

総合スコア187

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

0クリップ

投稿2016/10/08 18:02

AWSを使って簡易なレンタルサーバーを組んでいます。

Amazon Linux AMI 2016.03.3 x86_64 HVM で
インスタンスを作っています。

そこでデータベースを使いたく、
Mysqlを使う必要が出てきたのですが、
ユーザー作成について効率の良い方法を教えてください。

RDSなども考えたのですが、
ユーザー数が増えれば料金がかなり高くなってしまうので、
そういうのはなしにしたいです。

やりたいことを簡単に説明すると、
レンタルサーバーにユーザーが登録をすると、
/home/以下にユーザーのディレクトリができます。

ユーザーはここに対して、
ファイルを自由にアップできます。
(quotaを使って1ユーザー2GBまでに制限)

そこでワードプレスを使うために
ユーザーがMysqlのユーザー登録を自由にできるようにします。

通常Mysqlのユーザー登録といえば、
以下のようなSQL文を実行するかと思います。

━━━━━━━━━━━━━━━━━━
CREATE USER user IDENTIFIED BY [PASSWORD] 'password';
━━━━━━━━━━━━━━━━━━

これをperlとかで書いたCGIを使った場合に、
どう書けばいいのかに悩みまして。

「DBI->connect」でデータベースに接続しますが、
今回はその前段階のユーザー作成になります。

仮にrootユーザーで他のユーザーを作成する場合、
どういう感じにすると効率がいいんでしょうか。

perl register.cgi [ユーザー名] [パスワード]

のように実行したら、
Mysqlのユーザー作成がしたいです。

実際にはユーザー名やパスワードは
post送信とかで飛ばしてもらいます。

コマンドラインでやるなら以下で書けばいいのですが、
毎回ログインして実行していられないので。
━━━━━━━━━━━━━━━━━━
mysql -u root -p
mysql > create user ...
━━━━━━━━━━━━━━━━━━

こんな感じでやればいいというヒントがあれば、
教えていただけますと幸いです。

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

MySQLコンソールに限らず、正しいアカウントで接続すれば、PerlなどプログラムからでもCREATE USERなどを投げることができるはずです。

投稿2016/10/09 00:57

maisumakun

総合スコア145183

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

1nakaji

2016/10/09 08:59 編集

$dbh = DBI->connect($dsn, $user, $password); こんな感じで接続すれば、 そのまま投げられるという意味であってますか? $dsn = "DBI:mysql:database=$database;host=$hostname;port=$port"; その場合はデータベースを指定せず、 ━━━━━━━━━━━━━━━━━━ dsn = "DBI:mysql:host=$hostname;port=$port"; ━━━━━━━━━━━━━━━━━━ という感じでも問題ないんでしょうか。
1nakaji

2016/10/11 15:26

アドバイスを元にやってみたところ問題なく動作しました。 ありがとうございました。 ━━━━━━━━━━━━━━━━━━ #!/usr/bin/perl use strict; use warnings; use DBI; my $db_source = 'DBI:mysql:'; my $user = ''; my $pass = ''; my $mk_db = $ARGV[0]; my $dbh = DBI->connect($db_source, $user, $pass) || die $DBI::errstr; print 1 == $dbh->do("create database " . $mk_db ) ? "DB作成に成功\n":"DB作成に失敗\n"; ━━━━━━━━━━━━━━━━━━
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問