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

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

新規登録して質問してみよう
ただいま回答率
85.50%
さくらのVPS

さくらのVPSは、さくらインターネット社が提供するVPS(仮想専用サーバー)です。高速なSSDの選択や複数台構成も可能。利用者に応じた柔軟なプランが用意されています。大規模システムにも対応可能なスケーラビリティを備えたホスティングサービスです。

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

VPS

VPS(バーチャル・プライベート・サーバ)は、仮想化されたサーバをレンタルするサービスで、共有サーバでありながら専門サーバと同等の機能を果たします。物理的な専門サーバより安価で提供できるメリットがあります。

Q&A

2回答

1109閲覧

VPS上にデプロイしたアプリとローカルPCのDBとの接続

chikara

総合スコア6

さくらのVPS

さくらのVPSは、さくらインターネット社が提供するVPS(仮想専用サーバー)です。高速なSSDの選択や複数台構成も可能。利用者に応じた柔軟なプランが用意されています。大規模システムにも対応可能なスケーラビリティを備えたホスティングサービスです。

JDBC

JDBC(Java DataBase Connectivity)は、Javaとリーレーショナルデータベースに接続させる基本的なAPIです。Java上でSQLステートメントを発行することで、データベースの種類に影響を受ないDB操作を可能とします。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Spring

Spring Framework は、Javaプラットフォーム向けのオープンソースアプリケーションフレームワークです。 Java Platform上に、 Web ベースのアプリケーションを設計するための拡張機能が数多く用意されています。

VPS

VPS(バーチャル・プライベート・サーバ)は、仮想化されたサーバをレンタルするサービスで、共有サーバでありながら専門サーバと同等の機能を果たします。物理的な専門サーバより安価で提供できるメリットがあります。

0グッド

0クリップ

投稿2022/01/13 05:53

Javaを勉強し始めて1年ちょっとの初心者です。

Spring Tool Suite 4を使ってWebアプリを作成し、Mavenビルドでjarファイルにして
VPS上にデプロイしたのですが、Webアプリを起動すると下記エラーが発生しました。

Java

1//一部省略してます 2 3com.mysql.cj.jdbc.exceptions.CommunicationsException: Communications link failure 4 5The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server. 6 at com.mysql.cj.jdbc.exceptions.SQLError.createCommunicationsException(SQLError.java:174) ~[mysql-connector-java-8.0.22.jar!/:8.0.22] 7 at com.mysql.cj.jdbc.exceptions.SQLExceptionsMapping.translateException(SQLExceptionsMapping.java:64) ~[mysql-connector-java-8.0.22.jar!/:8.0.22] 8 at com.mysql.cj.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:836) ~[mysql-connector-java-8.0.22.jar!/:8.0.22] 9 at com.mysql.cj.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:456) ~[mysql-connector-java-8.0.22.jar!/:8.0.22] 10 at com.mysql.cj.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:246) ~[mysql-connector-java-8.0.22.jar!/:8.0.22] 11 at com.mysql.cj.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:198) ~[mysql-connector-java-8.0.22.jar!/:8.0.22] 12 at com.zaxxer.hikari.util.DriverDataSource.getConnection(DriverDataSource.java:138) ~[HikariCP-3.4.5.jar!/:na] 13 at com.zaxxer.hikari.pool.PoolBase.newConnection(PoolBase.java:358) ~[HikariCP-3.4.5.jar!/:na] 14 at com.zaxxer.hikari.pool.PoolBase.newPoolEntry(PoolBase.java:206) ~[HikariCP-3.4.5.jar!/:na] 15 at com.zaxxer.hikari.pool.HikariPool.createPoolEntry(HikariPool.java:477) [HikariCP-3.4.5.jar!/:na] 16 at com.zaxxer.hikari.pool.HikariPool.checkFailFast(HikariPool.java:560) [HikariCP-3.4.5.jar!/:na] 17 at com.zaxxer.hikari.pool.HikariPool.<init>(HikariPool.java:115) [HikariCP-3.4.5.jar!/:na] 18 at com.zaxxer.hikari.HikariDataSource.getConnection(HikariDataSource.java:112) [HikariCP-3.4.5.jar!/:na] 19 at org.hibernate.engine.jdbc.connections.internal.DatasourceConnectionProviderImpl.getConnection(DatasourceConnectionProviderImpl.java:122) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 20 at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator$ConnectionProviderJdbcConnectionAccess.obtainConnection(JdbcEnvironmentInitiator.java:180) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 21 at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:68) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 22 at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.initiateService(JdbcEnvironmentInitiator.java:35) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 23 at org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.initiateService(StandardServiceRegistryImpl.java:101) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 24 at org.hibernate.service.internal.AbstractServiceRegistryImpl.createService(AbstractServiceRegistryImpl.java:263) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 25 at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:237) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 26 at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:214) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 27 at org.hibernate.id.factory.internal.DefaultIdentifierGeneratorFactory.injectServices(DefaultIdentifierGeneratorFactory.java:152) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 28 at org.hibernate.service.internal.AbstractServiceRegistryImpl.injectDependencies(AbstractServiceRegistryImpl.java:286) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 29 at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java:243) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 30 at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java:214) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 31 at org.hibernate.boot.internal.InFlightMetadataCollectorImpl.<init>(InFlightMetadataCollectorImpl.java:176) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 32 at org.hibernate.boot.model.process.spi.MetadataBuildingProcess.complete(MetadataBuildingProcess.java:127) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 33 at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.metadata(EntityManagerFactoryBuilderImpl.java:1224) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 34 at org.hibernate.jpa.boot.internal.EntityManagerFactoryBuilderImpl.build(EntityManagerFactoryBuilderImpl.java:1255) [hibernate-core-5.4.25.Final.jar!/:5.4.25.Final] 35 at org.springframework.orm.jpa.vendor.SpringHibernateJpaPersistenceProvider.createContainerEntityManagerFactory(SpringHibernateJpaPersistenceProvider.java:58) [spring-orm-5.2.12.RELEASE.jar!/:5.2.12.RELEASE] 36 at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:551) ~[spring-context-5.2.12.RELEASE.jar!/:5.2.12.RELEASE] 37 at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:141) ~[spring-boot-2.2.12.RELEASE.jar!/:2.2.12.RELEASE] 38 at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:747) ~[spring-boot-2.2.12.RELEASE.jar!/:2.2.12.RELEASE] 39 at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:405) ~[spring-boot-2.2.12.RELEASE.jar!/:2.2.12.RELEASE] 40 at org.springframework.boot.SpringApplication.run(SpringApplication.java:315) ~[spring-boot-2.2.12.RELEASE.jar!/:2.2.12.RELEASE] 41 at org.springframework.boot.SpringApplication.run(SpringApplication.java:1226) ~[spring-boot-2.2.12.RELEASE.jar!/:2.2.12.RELEASE] 42 at org.springframework.boot.SpringApplication.run(SpringApplication.java:1215) ~[spring-boot-2.2.12.RELEASE.jar!/:2.2.12.RELEASE] 43 at jp.kuroda.sampleBlog.SampleBlogApplication.main(SampleBlogApplication.java:17) ~[classes!/:0.0.1-SNAPSHOT] 44 at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_312] 45 at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_312] 46 at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_312] 47 at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_312] 48 at org.springframework.boot.loader.MainMethodRunner.run(MainMethodRunner.java:48) ~[sampleBlog-0.0.1-SNAPSHOT.jar:0.0.1-SNAPSHOT] 49 at org.springframework.boot.loader.Launcher.launch(Launcher.java:87) ~[sampleBlog-0.0.1-SNAPSHOT.jar:0.0.1-SNAPSHOT] 50 at org.springframework.boot.loader.Launcher.launch(Launcher.java:51) ~[sampleBlog-0.0.1-SNAPSHOT.jar:0.0.1-SNAPSHOT] 51 at org.springframework.boot.loader.JarLauncher.main(JarLauncher.java:52) ~[sampleBlog-0.0.1-SNAPSHOT.jar:0.0.1-SNAPSHOT] 52Caused by: com.mysql.cj.exceptions.CJCommunicationsException: Communications link failure 53 54The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.

自分のノートパソコン上で起動した時は問題なく動いたので、VPSからノートパソコン上のDBにアクセスするためにVPSに何かしら設定する、もしくはapplication.propertiesのコードを改善する必要があると思って調べたのですが、解決に至りませんでしたorz

VPS上のWebアプリからローカルPCのDBにアクセスするにはどうすれば良いでしょうか?
ご教授お願い致します。

参考にした記事
JDBC経由でMySQLに突然接続できなくなった
さくらVPSでSpringBootを動かす

開発環境
Java 8
spring boot 2.2.12
10.4.22-MariaDB - mariadb.org binary distribution

開発ツール
Spring Tool Suites4
xampp 8.1.1
phpMyAdmin 5.1.1

さくらのVPS
CentOS Linux release 7.9.2009 (Core)
openjdk version "1.8.0_312"
OpenJDK Runtime Environment (build 1.8.0_312-b07)
OpenJDK 64-Bit Server VM (build 25.312-b07, mixed mode)

Linux7

1#firewall-cmd --list-ports 28080/tcp 3306/tcp 3#firewall-cmd --list-services 4dhcpv6-client http https ssh tomcat

Java

1spring.jpa.hibernate.ddl-auto=update 2spring.datasource.url=jdbc:mysql://localhost:3306/postarticle?enabledTLSProtocols=TLSv1.2 3spring.datasource.username=***** 4spring.datasource.password=*****

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

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

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

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

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

guest

回答2

0

ssh の RemoteForward 機能を使うといいと思います。
MariaDB ではなく PostgreSQL の例ですが、参考になると思います。
EC2インスタンスからローカルのpostgresqlに接続

投稿2022/01/13 12:37

TaichiYanagiya

総合スコア12141

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

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

chikara

2022/01/14 07:22

@TaichiYanagiyaさん、回答ありがとうございます。 拝見させて頂きました。 リモートフォワード機能について不勉強なため、下記記事も参考にしましたが、 (EC2ユーザー)@(EC2ホスト)の部分をどう書き換えればいいかわかりませんでしたorz 教えて頂けると助かります! [https://qiita.com/mechamogera/items/b1bb9130273deb9426f5](sshポートフォワーディング) [https://www2.filewo.net/wordpress/2019/03/31/【改訂版】sshポートフォワード(sshトンネル)【ロ/](【改訂版】SSHポートフォワード(SSHトンネル)【ローカル・リモート・ダイナミック総集編】)
TaichiYanagiya

2022/01/15 13:53

EC2ユーザー、ホストをそのままさくらVPS のユーザー、ホストに置き換えます。 ポート番号は MariaDB だと 3306 です。
chikara

2022/01/30 06:37

返答遅くなり、申し訳ありません。 ssh -f -N -R 3306:[VPSのIPアドレス]:3306 [VPSのユーザー]@[VPSのホスト] と入力しましたが、 ssh: connect to host [VPSのホスト] port 22: Connection refused と表示され、接続できません。sshdかfirewallの設定に問題があるのでしょうか?
TaichiYanagiya

2022/02/03 15:01

あれ? 今まで SSH ログインはできていたのですよね? まずは、SSH ログインできることを確認ください。 firewalld で ssh (TCP 22番) は許可されているようですが、sshd_config でポート番号を 22 から変更していないか、など。 あと、ssh コマンド実行ホストのローカルの 3306 番(localhost:3306 あるいは 127.0.0.1:3306) が接続先ですので、『ssh -f -N -R 3306:127.0.0.1:3306 [VPSのユーザー]@[VPSのホスト]』だと思います。
guest

0

VPS上のWebアプリからローカルPCのDBにアクセスするにはどうすれば良いでしょうか?

spring.datasource.url=jdbc:mysql://localhost:3306/pos

VPSにデプロイしたアプリケーションからみたとき、localhostは、あなたの手元のPCではないでしょう。IPアドレスなりホスト名なりを指定してみてはどうでしょうか。

投稿2022/01/13 06:14

shiketa

総合スコア3971

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

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

chikara

2022/01/14 06:32

@shiketaさん、回答ありがとうございます! spring.datasource.url=jdbc:mysql://localhost:3306/postarticle…の localhostの部分を自分のパソコンのIPアドレス、もしくはホスト名にするということでしょうか? 試してみたのですが、結果は変わらずでしたorz
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問