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

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

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

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Spark

Spark(Apache Spark)とは、膨大なデータを迅速、柔軟に分散並行処理を行うフレームワークです。分析ツールであるApache Hadoopと比較し、最大で100倍の速度でデータ処理ができるとされています。

Q&A

2回答

742閲覧

毎回ポート開放をターミナルで行っています。他の方法があると思うのですが、、

pom4010

総合スコア0

Java

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Spark

Spark(Apache Spark)とは、膨大なデータを迅速、柔軟に分散並行処理を行うフレームワークです。分析ツールであるApache Hadoopと比較し、最大で100倍の速度でデータ処理ができるとされています。

0グッド

0クリップ

投稿2020/08/01 14:26

プログラム更新毎にポート開放の手順を踏み、手間がかかるので他の方法を知りたいです。

現在、eclipseを用いてSparkフレームワークを用いたwebアプリの開発を行っています。
mainのjavaファイルを編集する度に、以下の手順を毎度行なわなければ編集内容が反映されません。

1.ターミナル上で「lsof -i:4567」を実行
2.ターミナル上で「kill (PID番号)」を実行
3.eclipseで「実行」=>「Javaアプリケーション」
4.ブラウザで結果の確認

毎回このポート開放手順を踏むのが非常に煩雑に感じるのですが、他の方法はないのでしょうか?
Tomcatの用に停止、再開だけで変更内容が反映されるようには、なっていないのでしょうか。

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

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

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

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

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

guest

回答2

0

終了に関しては、stop()メソッドを呼び出してサーバーである自プロセスを終了させましょう。
Stopping the Server - Spark Documentation

ですが、stop()メソッドをただ実行するとjava.lang.InterruptedExceptionが発生して具合が良くないようなので、そんな場合は下記 Sparkのissueに従ってスレッドにして対応する必要がありそうです。
spark Calling stop() causes java.lang.InterruptedException #563 - github

私自身は試していないので、バージョンや実行環境にもよることもあるかもしれません。

投稿2020/08/02 02:59

dodox86

総合スコア9256

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

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

pom4010

2020/08/04 06:41

windowsの環境だとコンソールの停止とJavaアプリケーションの実行だけで、変更内容が変更されました。 macとwindowsの違いということなのでしょうか。
dodox86

2020/08/04 06:48

eclipseも関係しているかもしれませんが、コンパイル済みJavaアプリケーションが実行中は、*.classファイルがJVMによって使用中になっているはずです。本来、ソースファイルの*.javaはこのときは使われていないので、編集などができてもよさそうですが、eclipseの実行中はデバッガーとの兼ね合いもあって、*.javaソースファイルはロックされているかもしれません。そんな場合、編集結果が反映されるのがOSや実行環境で異なることも考えられそうです。macOS、Windowsですとファイルシステムも違うので、それも関係しているかもしれません。(あくまで推測ですが)
dodox86

2020/08/04 06:56

> eclipseの実行中はデバッガーとの兼ね合いもあって、*.javaソースファイルはロックされているかもしれません。 ああ、いえ、たぶん、*.javaファイルは編集して保存できているのでしょうね。保存後のコンパイル~実行で修正内容が反映されるはずですが、そうならないのだとしたら、macOS上で、eclipseで実行しているときは適切に終了できず、プロセスが解放されず、(JVMが動きっぱなしか?)、従ってTCPポートも使われているままなのだと思います。Windowsでコンソール停止、Javaアプリ再実行であれば確実に編集後の*.classファイルが使われているのでしょう。
guest

0

最初から、そのポートを使ってるプロセスを、起動させないようにすればいいだけなんでは

投稿2020/08/01 22:53

y_waiwai

総合スコア88042

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

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

pom4010

2020/08/02 02:19

ポート番号4567は、このプログラムでしか使っておりません。 簡潔に質問をお伝えするとsparkフレームワークアプリの再実行方法は、どのようにするのか?ということです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問