MySQLのConnector/J (JDBC)のconnectTimeoutとsocketTimeout #MySQL

MySQLのConnector/J (JDBC)にはconnectTimeoutとsocketTimeoutのパラメータがあり、JDBCの接続文字列に追加することで設定できる。 MySQL :: MySQL Connector/J 5.1 Developer Guide :: 5.1 Driver/Datasource Class Names, URL Syntax and Configuration Pr…

mysqlのdockerイメージを使ってみた #MySQL #docker

概要 DockerHubにあるMySQLの公式イメージを使ってみた。 ※Docker for Mac使用 https://hub.docker.com/_/mysql/ イメージを持ってくる 5.6のイメージを使ってみることにする。 $ docker pull mysql:5.6 ダウンロードを確認 $ docker images 起動する とりあ…

Macにdelveを導入する #golang

goのデバッグができるというdelveの導入を試みる。 基本こいつにしたがってやってみた。 github.com brewしてみる $ brew install go-delve/delve/delve キーチェインに証明書を追加 こちらを参考に。 github.com dlv-cert.cfg を作成 [ req ] default_bits …

JJUG CCC 2017 Fall CfPに応募してみた #jjug_ccc

初心者枠があったので、ダメ元で応募してみた。 JJUG CCC 2017 Fall CfP 募集開始しました | 日本Javaユーザーグループ 参考にしたもの CfPどうやって書くのがいいかな、って思ってたら同僚が色々教えてくれた。 その中でも特に参考になったもの。 blog.buil…

SpringBoot+MyBatisでRDBMS毎にSQLを切り替える #mybatis

概要 RDBMS毎(例えばMySQLとPostgreSQL)で同じ目的のSQLでも構文に違いがあったりする。 MyBatisでは VendorDatabaseIdProvider を使うと、接続先のDBによって発行するSQLを切り替えることができる。 SpringBootで利用する方法についてまとめる。 VendorDa…

PostgreSQLでコマンドラインからSQLファイルを実行する

概要 PostgreSQLでコマンドラインから、特定のスキーマに対してSQLを発行する方法 準備 psql postgres 等で適当なデータベースに入ってroleの作成 create role commander with login; コマンドラインからデータベースの作成 $ createdb --owner commander co…

Goでコマンドラインオプションを受け取る

概要 Golangでコマンドラインオプションを受け取る方法。 go-sample というプログラムがあった場合に、 go-sample -hoge="bbb" と実行して、 bbb を受け取る。 手順 flagパッケージをimportします。 import ( "flag" ) flag変数(コマンドラインオプションを…

社内でモブプログラミング交流会を開催しました #MobProgramming

モブプロをもっとみんなで楽しみたい!の思いから社内でモブプロでの交流会開催しました。 業務後に希望者で集まって、軽くお酒とお菓子も用意して、ゆるーく楽しめる会を目指しました。 開催にあたって、以前参加させていただいた Mob Programming Val を参…

GO言語でHello Worldしてみた #golang

Macで Hello golang してみた。 インストール brew install go bash_profileの編集 export GOPATH=$HOME/go export PATH=$PATH:$GOPATH/bin 追記して source する。 ワークスペースの作成 mkdir $HOME/go mkdir -p $GOPATH/src/github.com/su-kun1899 プロジ…

Visual Studio Codeの設定をいじってみた

Qiitaの記事を参考に修正してみた。 qiita.com 一部上記の記事では古くなっている設定項目もあったが、設定画面で丁寧に説明が書いてあるので特に困らなかった。 最終的に出来上がったのがこちら。 { // フォントファミリー(お好みで) "editor.fontFamily": …

RabbitMQをMacにインストールしてみた

Homebrewでインストール brew install rabbitmq 起動 /usr/local/sbin/rabbitmq-server detachedを付けるとバックグラウンド実行らしいが、何か警告が出る。 $ /usr/local/sbin/rabbitmq-server -detached Warning: PID file not written; -detached was pas…

ls がどうにもこうにも帰ってこないとき

サーバで、このディレクトリ何だろ?と思って ls を打ってみたけど、待てど暮せど帰ってこない。 どうやら大量にファイルがあるみたい。 それでも見たい、そんなとき。 -U オプションを使う lsはソートをしてろい、ソートに時間がかかっているらしい。 -U を…

spring-security-testを使おう

Spring Securityを使ってるSpring BootのWebアプリでテストを書く時に、認証自体をテストしたいのでなければ spring-security-test で認証情報を簡単にMockできる。 pom.xml spring-security-test を dependency に追加する <dependency> <groupId>org.springframework.boot</groupId> <artifactId>sprin</artifactid></dependency>…

「Global Scrum Gathering参加報告会&Hunter Industries社の見学報告会」に参加してきた #ScrumTokyo

www.eventbrite.com 「Global Scrum Gathering参加報告会&Hunter Industries社の見学報告会」に参加してきた。 内容は下記の3つ。 Global SCRUM GATHERING San Diego 2017への参加報告 Hunter Industries社への訪問リポート Global SCRUM GATHERING® Singa…

spring-bootアプリをherokuにデプロイする #heroku #SpringBoot

前提 herokuのアカウントは作成済 SpringBoot単独で起動可能にしている(外部DB等を必要としない) git管理されている heroku CLIのインストール Macだとhomebrew。 brew install heroku Heroku CLI | Heroku Dev Center Procfileの作成 プロジェクト直下に …

モブプロディスカッションに参加してきた! #mobProgramming #MobDiscussion

モブプロディスカッションに参加してきました! www.eventbrite.com 内容としては及部さんがDevLOVEの講演の再演をした後、会場の質問を中心にパネラーがディスカッションするというもの。 自分のチームでモブプログラミング、モブワークをし始めてだいぶこ…

gitignoreでホワイトリストを作成する #git

git

gitignoreで、明示的に指定したファイルしか扱えないようにホワイトリストを作成する方法について(意外と手間取ったので)残しておく。 ホワイトリスト方式とは ここではgit管理において、明示的にgitignoreに指定したファイル以外バージョン管理としないと…

モブプログラミングに実況システム導入するのおすすめです #MobProgramming

僕らのモブチームは実況システムというのを導入しているのだけれど、それがとてもいい感じなので紹介したい。 実況システムとは 思ったことや感じたことを皆が気軽に発言、共有できる場を用意すること。 モブプログラミング中にリアルタイムで加筆、修正して…

ドットインストールの独習会に参加しました #dotinstall

ドットインストールの独習会に参加してきた。 『ドットインストール』公式ブログ - 【7月6日】そろそろ時間をとってJavaScriptを勉強したい人向け自習会を行います 実は今回で参加するのは二回目。 抽選で当たった模様。倍率は知らない笑 前半はもくもく会で…

構文解析ハンズオンに参加してきました #構文解析ハンズオン

ちょっと行ったことのない感じの勉強会に参加してきました。 lang-impl.connpass.com GitHubにテストコードと回答の付いたソースコードがあって、cloneしてテストを通すようにする流れ。 午前中にイントロダクション的な講義があった後は、課題の説明→コード…

モブプロに魔法感あった #mobProgramming #ちら裏

概要 もう最近はずっと、チームの作業は基本的にモブプログラミングになってる。(今は6人体制) ちょっと印象に残る出来事があったので残しておく。 きっかけ 今進めている実装で、一部モヤモヤすることところがあった。 ちょっとテストがめんどくさかった…

ネストしたオブジェクトのマッピングする #MyBatis

MyBatisでネストしたオブジェクトマッピングするサンプルあんまり見かけないので、残しておく。 例えばこんなデータを person id name address_id 1 yamada 11 2 sato 11 address id city 11 tokyo book id title 21 hoge 22 fuga 23 piyo person_book perso…

すでに存在するデータベースにFlywayを適用する(その2) #flyway

概要 下記記事の続き。 今度はbaselineの設定を活用して、SQLとFlywayの足並みを調整する。 su-kun1899.hatenablog.com テスト用のデータベースを作る create database if not exists flyway_sample character set utf8 flyway管理外のテーブルを追加する my…

すでに存在するデータベースにFlywayを適用する #flyway

概要 Baselineを使って、MySQL+Mavenで、FlywayによるDB構成管理を既に存在するデータベースに適用する。 Flyway by Boxfuse • Database Migrations Made Easy. テスト用のデータベースを作る create database if not exists flyway_sample character set ut…

SonarQubeを使ってみた #sonarqube

概要 Javaで作ってるリポジトリにSonarQubeを適用してみました。 SonarQubeとは? SonarQubeは、ソースコードの静的解析ツールです。 www.sonarqube.org 今回はオープンソースであれば無料で使えるSonarQube.comを利用します。 about.sonarqube.com アカウン…

GitHubのAPIを使って、Releaseコンテンツを取得する

概要 GitHubのAPIも触らないまま大人になってしまった。 せっかくなのでモブプロにお世話になっているMobsterをAPI経由でダウンロードしてみます。 Releaseコンテンツ リリースページからDownloadできるやつらのことです。 APIの表現だとassetsというようで…

nodebrewでNode.jsをインストールしてHello World

nodebrewのインストール インストール。 $ curl -L git.io/nodebrew | perl - setup bash_profileにPATHを追加 export PATH=$HOME/.nodebrew/current/bin:$PATH $ source .bash_profile Node.jsのインストール 7.9.0をインストール $ MAKE_OPTS="-j 2" nodeb…

ローカルで作成したブランチがリモート追跡されない #git

Git

ローカルで新規にブランチを作成してpush git push origin [ブランチ名] リモートのブランチを追跡してくれない。 git branch -vv しても追跡ブランチが出てこない。 set-upstream-toを使う git git branch --set-upstream-to=origin/[ブランチ名] これで gi…

Javaで期間の日数を計算する #java

概要 2016年1月7日から2017年4月27日みたいな期間の日数を数える方法。 Period…惜しい 日付の期間を扱うには java.time.Period クラスがあるが、悲しいことに日数をカウントするAPIがない。 getDays() は日付だけで計算をするため、月をまたいだ日数のカウン…

CircleCIでjacocoのカバレッジレポートをとる #circleCi #jacoco #java

概要 SpringBoot + Spock + maven で開発をしているんだけれど、せっかくテストも書いているのでカバレッジレポートをCI時に取得するようにする。 pom.xmlにjacocoプラグインを追加 ... <build> ... <plugins> ... <plugin> <groupId>org.jacoco</groupId> <artifactId>jacoco-maven-plugin</artifactId> <version>0.7.9</version> <executions> <execution> <id>prepare-agent</id> </execution></executions></plugin></plugins></build>

flywayで差し込みバージョンを適用する #flyway

こんな感じの時、間に差し込みバージョンを作る。 +------------+-----------------+---------------------+---------+ | Version | Description | Installed on | State | +------------+-----------------+---------------------+---------+ | 1.0 | init …

IntelliJ IDEAでフォーマットを一部無効にする #IntelliJIdea

コードのフォーマットは基本IDEAにおまかせなのですが、どうしても一部フォーマットをカスタマイズしたいことはあると思います。 JavaのStreamでごりごりやる時とか、Spockのwhereブロックとか。 んで、せっかくキレイにしたのにうっかりファイルにフォーマ…

Eachの中でassertするときは明記する必要がある #spock

Spockでは通常、thenブロックの中はbool値を返すようにしておけば勝手にアサーションしてくれる。 then: actual == expect ただし、イテレーションの中はアサーションしてくれない then: actualArray.each { it.getName == expectName // falseでもテストNG…

Mavenで特定のクラスのテストだけ実行する #maven #java

特定のテストだけ mvn test -Dtest=red.sukun1899.SampleSpec クラス名が一意になるなら、パッケージは省略できる mvn test -Dtest=SampleSpec 複数の場合はカンマでつなぐ mvn test -Dtest=HogeSpec,FugaSpec 特定のメソッドだけ実行する場合シャープでつな…

TDDっぽくモブプログラミングしてみた #MobProgramming

最近はまっていることがあるんですけど。。と同僚に言ったら「モブプログラミングですか?」と聞かれる程度にはハシャいでおります。 先日はTDDな感じでやってみました。 (結果的にそうなったけれど、そうしようとして始めた感じではなかったかも) ちょっ…

データ抽出のテストにはモブプログラミングを使うといいかも #MobProgramming

モブプログラミングとは? この記事では複数人で行われるプログラミングの意です。 ペアプロの延長線上だと考えて下さい。 正確な定義とは異なるかもしれません。 参考までに以前書いた記事です。 su-kun1899.hatenablog.com データ抽出のテストって? 何ら…

最良の日だったかもしれない #ちら裏 #ポエム

転職して、一年ちょっとが経ったにもかかわらず、モヤモヤしながらもがき苦しんでるわけですが、今日は入社してから一番いい日だったかもしれない。 何があった とあるモジュールがSVNで構成管理をしているんだけれど、GitHubに移行することになった。 自分…

ネストしたオブジェクトでAutoMappingを使う #mybatis

MybatisのネストしたresultMapの自動マッピングはデフォルトPARTIALになっている。 つまり、ネストしたオブジェクトのauto-mappingは効かないということ。 これだといちいちマッピングを定義してやらなきゃいけないのでとてもつらいのだが、設定を変えなくて…

意見 #ちら裏 #ポエム

自分を信じよう 自分の知識・経験をフル稼働させて出した答えを信じ、大切にしたほうがよい。 他人の方が優秀かもしれないが、自分ではない。 もっとも信頼できるのは自分自身であるべきだ。 自分を疑おう 自分の出した答えを疑ったほうがよい。 世の中には…

IntelliJ IDEAで括り放題 #intellijidea

職場の同僚に教えてもらったのだが、Surround selection on typing quote or brace を有効にするといいかもしれない。 括弧やクォートで括り放題になる。 括っている文字の置き換えもIDEAさんがいい感じにやってくれる。 どういうことかというと。。 これを…

モブプログラミングやってみたら最高だった #MobProgramming

今日チームでモブプログラミングを初めてやってみたのだけれど、最高だったのでテンションのままにブログを書く。 きっかけ ふりかえりでたまたまJoy.Incの話になり、あの会社は全部ペアでやってるらしく、ペアプロしたくなるという話をした。 そうしたら、…

application.ymlの値をJavaアプリケーション側で受け取る #SpringBoot

org.springframework.beans.factory.annotation.Value を使うとよい。 ただし、まとまった単位で管理したいときは @ConfigurationProperties を使うのがよさげ。 例 @Configuration public class AppConfig { @Value("${spring.datasource.schema}") private…

SpringBootでMybatisの設定を動的に書き換えられないか挑戦してみた(失敗した)

MyBatisのConfigをJava側で動的に書き換えられないか調べてみた。 結果できなかったんだけど、備忘録として。 stackoverflow.com org.apache.ibatis.session.Configuration に値を突っ込むことでどうにかなりそう? configuration.getVariables().put("globa…

JavaScriptのargumentsオブジェクトは配列じゃないのか。。 #javascript #js

JavaScriptでargumentsオブジェクトは配列っぽいけど配列ではないらしい。 なので配列のメソッド呼ぼうとしてもエラーになる。 ES2015以前 Array.prototype.slice.call で配列に変換してあげるのがよいっぽい。 var args = Array.prototype.slice.call(argum…

Mavenでコマンドライン引数を渡す

run.argumentsプロパティで渡してあげるとよい。 Sample: ./mvnw spring-boot:run -Drun.arguments="arg1, arg2" 参考 stackoverflow.com

Javaの文字列結合はどうしたものか #java

以前はStringBuilderかStringBufferがお約束だったけども、String#joinがJava8から追加されてどうしたらいいものか。 StringJoinerなんてのもある。 というかString#joinは内部的にはStringJoinerを使っているらしい。 色々記事を漁ってみたものの、パフォー…

SpringBootでH2の管理コンソールを使う #springboot

spring:h2:console:enabled をtrueにするだけ。 spring: datasource: driver-class-name: org.h2.Driver url: jdbc:h2:mem:testdb;MODE=MYSQL username: sa password: h2: console: enabled: true SpringBoot起動後、下記にアクセスすると利用できる。 http:…

SpockでJavaの無名クラスを使ったらCircleCIがコケた #circleci #java #spock

CircleCIがテストの途中にタイムアウトでこけた。 command mvn test took more than 10 minutes since last output ログを見ても途中で止まっており、結果としてもタイムアウトなので検討つかない。 もちろんローカル環境では発生しない。 Revertなりなんな…

ジョイ・インクを読んだ #JoyInc #ポエム

「ジョイ・インク 役職も部署もない全員主役のマネジメント」を読んだ。 ある意味ぶっ飛んだ会社の話。 突拍子もないいくつもの仕組みが、「なぜ、そうするのか」次々に裏付けされていく。 どういう文化にしたいのか、どう向かっていくのか。 そして終盤、筆…

JavaのStreamで独自ソート #java

sortedにComparator Streamで独自ソートするにはsortedにComparatorを渡してやればOK。 List<Person> personsSortedByName = getPersons().stream() .sorted(new Comparator<Person>() { @Override public int compare(Person person1, Person person2) { return person1.get</person></person>…