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

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

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

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

MySQL

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

Linux

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

Q&A

解決済

3回答

2208閲覧

さくらVPS上のMySQLのデータベースにRubyからアクセスできない。

kvynnet

総合スコア7

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

MySQL

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

Linux

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

0グッド

0クリップ

投稿2015/10/12 12:07

現在、さくらVPSを利用していまして、dotinstall等を参考にしながらMySQLとApacheの設定をしました。
そこでRubyファイルにてMySQLのレコード一つを抽出して、コンソール上に表示する簡単なRubyプログラムを書いたのですがうまく表示できません。似たような処理をPHPでこちら(http://www.phpbook.jp/tutorial/mysql/index6.html)を参考にして作成したのですが同じエラーが出ました。MySQLクライアントではDBにアクセスできているので、host、port、username、passwordの値は問題ないと思われます。
情報が少ないかもしれませんが頂いた質問には随時答えたいと思います。
よろしくお願いいたします。

ruby 2.2.1
ubuntu 14.04
mysql 14.14

app.rb

# coding:utf-8 require 'mysql2' client = Mysql2::Client.new(:host => 'xxx.xxx.x.xxx',:port => 'xxxx',:database => 'test', :username => 'root', :password => 'pass') result = client.query("select name from test.users where id = 1") print result

error message :
/home/username/.rvm/gems/ruby-2.2.1/gems/mysql2-0.4.1/lib/mysql2/client.rb:79:in connect': Lost connection to MySQL server at 'reading initial communication packet', system error: 0 (Mysql2::Error) from /home/username/.rvm/gems/ruby-2.2.1/gems/mysql2-0.4.1/lib/mysql2/client.rb:79:in initialize'
from checkdb.rb:4:in new' from checkdb.rb:4:in <main>'

php error
PHP Warning: mysql_connect(): Lost connection to MySQL server at 'reading initial communication packet', system error: 0 in /var/www/html/public/check.php on line 2

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

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

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

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

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

guest

回答3

0

自己解決されたようで何よりです。

投稿2015/10/12 12:41

YamaguchiKenya

総合スコア69

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

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

0

はじめまして。こんにちは。
確認させて頂きたいことがあります。

MySQL を構築しているさくらVPSのサーバー上で ruby プログラムも動かされていますか?
それとも、ruby プログラムはサーバー上ではない別の場所から実行されていますか?

投稿2015/10/12 12:40

YamaguchiKenya

総合スコア69

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

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

0

自己解決

原因
host, portの勘違い

host=localhost
less /etc/mysql/my.cnf にてportを確認しそれを入力

投稿2015/10/12 12:38

kvynnet

総合スコア7

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問