2015年5月8日金曜日

Windows 10 on Raspberry pi 2

昨日ようやく Raspberry pi 2 向け Windows 10 のプレビュー版が利用できるようになったことに気付いたので早速やってみた。(新人研修の合間に)

こちらによると、 別に Windows 10 が入っている母艦機が必要らしく(まじで?)、まずはそっち から。
この時点で、会社に DVD-R の在庫が無くてコンビニに走る始末。萎えるわ。

母艦機にするために仕方なくインストールした Windows10 だけど、Windows 8.1 に比べるとかなりすっきり使いやすくなっている印象。これは今までの Windows の中では一番使いやすいと思われる。まだちょこちょこ不具合っぽいの残ってるみたいだけど。

こんな感じ↓


で、SDカードを pi 2 に刺しなおして本題の pi 2 の Windows 10。



なんというか、わかってはいたけど、
  • もっさり
  • 刺さりまくる
  • 勝手に再起動
という三重苦でした。
リリースまでに良くなることを期待。

今の時点では弄り倒す気持ちは起きなかったのでおとなしく Raspberian に戻そうか・・・・。

2015年4月24日金曜日

Ubuntu Server に、JDK 8 を apt だけで入れる

Ubuntu Server 14.04LTS には、OpenJDK 8 が無かった・・・・ので、Sun JDK 8 でも入れてみる。
そもそも Ubuntu Server に、add-apt-repository が入っていないのは、品質担保のため?

  • インストール
# apt-get install software-properties-common
# add-apt-repository ppa:webupd8team/java
# apt-get -y -q update
# echo oracle-java8-installer shared/accepted-oracle-license-v1-1 select true | /usr/bin/debconf-set-selections
# apt-get -y -q install oracle-java8-installer
# update-java-alternatives -s java-8-oracle
  • 動作確認
# java -version
java version "1.8.0_45"
Java(TM) SE Runtime Environment (build 1.8.0_45-b14)
Java HotSpot(TM) 64-Bit Server VM (build 25.45-b02, mixed mode)
 元ネタはこの辺です。
http://askubuntu.com/questions/464755/how-to-install-openjdk-8-on-14-04-lts
http://www.webupd8.org/2012/09/install-oracle-java-8-in-ubuntu-via-ppa.html

2015年3月2日月曜日

WildFly 8.2.0.Final on Raspberry pi 2

Raspberry pi 2 がリリースされ、RAM が 1GB になった。
普通に Java の AP サーバーが動いちゃうじゃないか。

・・・・・ということで、ポチっとしちゃいました。





確かにちっちゃい。今更だけどw




で、やらずには居られないいつもの結果です。

pi@raspberrypi /usr/local/jboss/wildfly-8.2.0.Final/bin $ ./standalone.sh -b 192.168.1.186
=========================================================================

  JBoss Bootstrap Environment

  JBOSS_HOME: /usr/local/jboss/wildfly-8.2.0.Final

  JAVA: java

  JAVA_OPTS:  -server -Xms64m -Xmx512m -XX:MaxPermSize=256m -Djava.net.preferIPv4Stack=true -Djboss.modules.system.pkgs=org.jboss.byteman -Djava.awt.headless=true

=========================================================================

Java HotSpot(TM) Server VM warning: ignoring option MaxPermSize=256m; support was removed in 8.0
11:25:13,595 INFO  [org.jboss.modules] (main) JBoss Modules version 1.3.3.Final
11:25:16,599 INFO  [org.jboss.msc] (main) JBoss MSC version 1.2.2.Final
11:25:17,395 INFO  [org.jboss.as] (MSC service thread 1-5) JBAS015899: WildFly 8.2.0.Final "Tweek" starting
11:25:26,121 INFO  [org.jboss.as.server] (Controller Boot Thread) JBAS015888: Creating http management service using socket-binding (management-http)
11:25:26,292 INFO  [org.xnio] (MSC service thread 1-3) XNIO version 3.3.0.Final
11:25:26,710 INFO  [org.xnio.nio] (MSC service thread 1-3) XNIO NIO Implementation Version 3.3.0.Final
11:25:26,968 WARN  [org.jboss.as.txn] (ServerService Thread Pool -- 46) JBAS010153: Node identifier property is set to the default value. Please make sure it is unique.
11:25:27,013 INFO  [org.jboss.as.security] (ServerService Thread Pool -- 45) JBAS013171: Activating Security Subsystem
11:25:27,025 INFO  [org.jboss.as.clustering.infinispan] (ServerService Thread Pool -- 32) JBAS010280: Activating Infinispan subsystem.
11:25:27,087 INFO  [org.jboss.as.naming] (ServerService Thread Pool -- 40) JBAS011800: Activating Naming Subsystem
11:25:27,161 INFO  [org.jboss.as.webservices] (ServerService Thread Pool -- 48) JBAS015537: Activating WebServices Extension
11:25:27,208 INFO  [org.jboss.as.security] (MSC service thread 1-5) JBAS013170: Current PicketBox version=4.0.21.Final
11:25:27,212 INFO  [org.wildfly.extension.io] (ServerService Thread Pool -- 31) WFLYIO001: Worker 'default' has auto-configured to 8 core threads with 64 task threads based on your 4 available processors
11:25:27,261 INFO  [org.jboss.as.jsf] (ServerService Thread Pool -- 38) JBAS012615: Activated the following JSF Implementations: [main]
11:25:27,531 INFO  [org.jboss.as.connector.logging] (MSC service thread 1-7) JBAS010408: Starting JCA Subsystem (IronJacamar 1.1.9.Final)
11:25:27,608 INFO  [org.wildfly.extension.undertow] (MSC service thread 1-1) JBAS017502: Undertow 1.1.0.Final starting
11:25:27,620 INFO  [org.wildfly.extension.undertow] (ServerService Thread Pool -- 47) JBAS017502: Undertow 1.1.0.Final starting
11:25:27,777 INFO  [org.jboss.as.connector.subsystems.datasources] (ServerService Thread Pool -- 27) JBAS010403: Deploying JDBC-compliant driver class org.h2.Driver (version 1.3)
11:25:27,823 INFO  [org.jboss.as.connector.deployers.jdbc] (MSC service thread 1-7) JBAS010417: Started Driver service with driver-name = h2
11:25:27,951 INFO  [org.jboss.as.naming] (MSC service thread 1-5) JBAS011802: Starting Naming Service
11:25:27,996 INFO  [org.jboss.as.mail.extension] (MSC service thread 1-8) JBAS015400: Bound mail session [java:jboss/mail/Default]
11:25:28,217 INFO  [org.jboss.remoting] (MSC service thread 1-3) JBoss Remoting version 4.0.6.Final
11:25:29,174 INFO  [org.wildfly.extension.undertow] (ServerService Thread Pool -- 47) JBAS017527: Creating file handler for path /usr/local/jboss/wildfly-8.2.0.Final/welcome-content
11:25:29,269 INFO  [org.wildfly.extension.undertow] (MSC service thread 1-8) JBAS017525: Started server default-server.
11:25:29,435 INFO  [org.wildfly.extension.undertow] (MSC service thread 1-7) JBAS017531: Host default-host starting
11:25:38,190 INFO  [org.wildfly.extension.undertow] (MSC service thread 1-8) JBAS017519: Undertow HTTP listener default listening on /192.168.1.186:8080
11:25:39,958 INFO  [org.jboss.as.server.deployment.scanner] (MSC service thread 1-2) JBAS015012: Started FileSystemDeploymentService for directory /usr/local/jboss/wildfly-8.2.0.Final/standalone/deployments
11:25:40,699 INFO  [org.jboss.as.connector.subsystems.datasources] (MSC service thread 1-3) JBAS010400: Bound data source [java:jboss/datasources/ExampleDS]
11:25:42,458 INFO  [org.jboss.ws.common.management] (MSC service thread 1-6) JBWS022052: Starting JBoss Web Services - Stack CXF Server 4.3.2.Final
11:25:43,037 INFO  [org.jboss.as] (Controller Boot Thread) JBAS015961: Http management interface listening on http://127.0.0.1:9990/management
11:25:43,041 INFO  [org.jboss.as] (Controller Boot Thread) JBAS015951: Admin console listening on http://127.0.0.1:9990
11:25:43,044 INFO  [org.jboss.as] (Controller Boot Thread) JBAS015874: WildFly 8.2.0.Final "Tweek" started in 33060ms - Started 184 of 234 services (82 services are lazy, passive or on-demand)
30秒か~なんとか使えなくもないかな?

2014年7月5日土曜日

ORA-28002 が出たら

Oracle パスワードに期限が付いたのを知りませんでした。
java.sql.SQLWarning: ORA-28002: the password will expire within 6 days
 とか出たら、面倒なのでとりあえずこれ叩いておきます。
alter profile default limit password_life_time unlimited;
alter user 接続ゆーざー identified by ぱすわーど;
# Oracle ネタはもう書かないと思います。

2014年6月8日日曜日

JBoss EAP 6.2 -> 6.2.x へのバージョンアップ

知らないうちに、patch を当てる形式になってたんですね。6.2 からかな?(*1)

https://access.redhat.com/site/documentation//en-US/JBoss_Enterprise_Application_Platform/6.2/html/Installation_Guide/Installing_Patches_in_Zip_Form_Using_the_patch_Command.html

成功するとこんな感じ(パッチファイルのパス削ってるので読み替えてね)



 JBoss を再起動すると・・・・


6.2.3.GA に代わります。


(*1) 中の人から下記情報を戴きました^^。やっぱり 6.2 かららしいです。
https://access.redhat.com/site/ja/articles/643163

2014年2月14日金曜日

OpenShift に WildFly が登場してた。

いつの間に。
CR1のカードリッジなのか。少しまつと、1.0.0.Final のに変わるかな?


2014年2月12日水曜日

ようやく出たね WildFly 8.0.0.Final

先ほどリリースされたのを確認できたので、とりあえず起動まで。
EE7 が普及してほしいので、早くEAPが出るといいなー。


2013年12月25日水曜日

WildFly 8.0.0.CR1

ようやく出てたのでとりあえずいつものブート。
久しぶりに、ZIP 版が生きてましたw



Final は1月末みたいですね。
https://issues.jboss.org/browse/WFLY?selectedTab=com.atlassian.jira.plugin.system.project%3Aroadmap-panel&_sscc=t


2013年11月13日水曜日

RESTEasy の Bean Validation

そんなの API で受けてから手動でやりなさいよ!と言われるかもしれないけどできることなら冗長なコードは排除したい。

そんなあなたに ExceptionMapper を使う方法を。

使い方が変わったようなので新旧書いときます。(大体同じようなことはしてますが全く同じではないので注意)

※RESTEasy 2.3 の方は EJB との組み合わせに問題がある・・・・ので、できれば RESTEasy 3 の方がおすすめです。

□WildFly 8.0.0.Beta1 & RESTEasy 3.0.4.Final
@Provider
public class ValidationExceptionHandler implements
        ExceptionMapper<ResteasyViolationException> {

    @Override
    @Produces(MediaType.APPLICATION_JSON)
    public Response toResponse(ResteasyViolationException exception) {

        ValidateMessage errors = new ValidateMessage();

        for (ResteasyConstraintViolation violation : exception.getViolations()) {
            errors.getMessages().add(
                    new Message(String.format("%s:%s:%s:%s", violation
                            .getPath(), violation.getConstraintType().name(),
                            violation.getValue(), violation.getMessage())));
        }

        return Response.status(Status.BAD_REQUEST).entity(errors).build();
    }
}
□JBoss AS 7.1.x & RESTEasy 2.3.x
@Provider
public class ValidationExceptionHandler implements
        ExceptionMapper<MethodConstraintViolationException> {

    @Override
    @Produces({ MediaType.APPLICATION_JSON })
    public Response toResponse(MethodConstraintViolationException ex) {
        ValidateMessage errors = new ValidateMessage();

        for (MethodConstraintViolation<?> violation : ex
                .getConstraintViolations()) {
            errors.getMessages().add(
                    new Message(String.format("%s:%s:%s:%s", violation
                            .getMethod().getName(), violation
                            .getParameterName(), violation.getInvalidValue(),
                            violation.getMessage())));
        }

        return Response.status(Status.BAD_REQUEST).entity(errors).build();
    }
}

□JSON 出力のためのドメインクラス
@XmlRootElement(name = "validate_message")
public class ValidateMessage implements Serializable {
    private static final long serialVersionUID = 1L;

    private List<Message> messages = new ArrayList<Message>();

    public static class Message {

        private String message;

        public Message() {
        }

        public Message(String message) {
            this.message = message;
        }

        public String getMessage() {
            return message;
        }

        public void setMessage(String message) {
            this.message = message;
        }

    }

    @XmlElementWrapper(name = "messages")
    @XmlElement(name = "message")
    public List<Message> getMessages() {
        return messages;
    }

    public void setMessages(List<Message> messages) {
        this.messages = messages;
    }
}

□pom.xml(RESTEasy 3.0.4.Final)
        <dependency>
            <groupId>org.jboss.resteasy</groupId>
            <artifactId>resteasy-validator-provider-11</artifactId>
            <version>3.0.4.Final</version>
            <scope>provided</scope>
        </dependency>
 □pom.xml(RESTEasy 2.3.x)
        <dependency>
            <groupId>org.jboss.resteasy</groupId>
            <artifactId>resteasy-hibernatevalidator-provider</artifactId>
            <version>2.3.7.Final</version>
        </dependency>

2013年9月26日木曜日

SwitchYard on OpenShift

デモビデオが出てたので貼っときます。
http://vimeo.com/75402902#

え。でも、OpenShift の SwitchYard って 0.4 じゃなかった?

・・・・と思ったら、0.8 に上がってました。なぜ 1.0 じゃない?w

あ、ここに纏められるみたいですね^^
https://community.jboss.org/wiki/SwitchYardVideoSeries

2013年9月11日水曜日

最近困っている不具合一覧

■解決して助かった問題
■新たに、jira に登録してもらった課題

2013年8月8日木曜日

Support injection of JMSContext

WildFly で JMS の @Inject アノテーションによるインジェクションができないという問題(正確には、JMS 2.0 機能が満たせてないだけ)があったのですが、対応が入ったみたいです。
https://issues.jboss.org/browse/WFLY-1286

コード量が少し減りますかね。

2013年7月29日月曜日

JBDS7

今朝、村形軍曹から、JBDS7 が出てるよ、と。

・・・・本当だ^^
http://planet.jboss.org/post/jboss_tools_4_1_and_developer_studio_7_go_ga

JBDS7 Beta2 からアップデートしてみる。








できた。


とりあえず、AS7.2~WildFlyを利用している人は更新必須ですかね~

2013年6月25日火曜日

GlassFish 4.0

いつの間にかリリースされてた。
https://glassfish.java.net/download.html

2013年6月24日月曜日

WildFly 8.0.0.Alpha2

リリースされてますね~
http://www.wildfly.org/download/
https://github.com/wildfly/wildfly/tree/8.0.0.Alpha2

あー、なんか Alpha1 で作ってたプロジェクトはそのままじゃ動かんな~w

2013年6月13日木曜日

OpenShift!

正式発表された、OpenShift にスモールサイズのインスタンスを作ってみたよ!
URL こういうの意外と取れるのねw

http://hoge-fuga.rhcloud.com/

さて・・・・置くモノが無いなw

2013年6月4日火曜日

Java EE 7 is Final!

気づくのが遅くなってしまいましたが、EE 7 spec が Final Release になっていました。
http://jcp.org/en/jsr/detail?id=342


あとは、個人的に気にしている spec を列挙しときます。(自分用のメモ)

WebSocket(JSR356)
http://www.jcp.org/en/jsr/detail?id=356

EJB 3.2(JSR345)
http://jcp.org/en/jsr/detail?id=345

JMS 2.0(JSR343)
http://jcp.org/en/jsr/detail?id=343

JAX-RS 2.0(JSR339)
http://jcp.org/en/jsr/detail?id=339

2013年5月18日土曜日

WildFly 8.0.0.Alpha1 をビルド

WildFly 8.0.0.Alpha1 のタグ付けがされたようなので、早速ビルドしてみたよ!

$ cd /path/to
$ git clone https://github.com/wildfly/wildfly.git
$ cd wildfly
$ git tag
7.0.0.Alpha1
7.0.0.Alpha1-final
7.0.0.Beta1
7.0.0.Beta1-prerelease
7.0.0.Beta2
7.0.0.Beta2-prerelease
7.0.0.Beta3
7.0.0.CR1
7.0.0.Final
7.0.0.Final-prerelease
7.0.0.Final-prerelease2
7.0.0.Final-prerelease3
7.0.1.Final
7.0.2.Final
7.0.2.Final-prerelease
7.0.2.SP1-prerelease
7.1.0.Alpha1
7.1.0.Beta1
7.1.0.Beta1b
7.1.0.Beta1b-prerelease
7.1.0.CR1
7.1.0.CR1b
7.1.0.Final
7.1.0.Final-prerelease
7.1.0.Final-prerelease2
7.1.1.Final
7.1.2-prerelease
7.1.2.Final
7.1.3.Beta1
7.1.3.CR1
7.1.3.Final
7.2.0.Final
7.2.0.Final-prerelease1
7.2.0.Final-testsuite-fix
8.0.0.Alpha1

$ git checkout -b new 8.0.0.Alpha1
$ JAVA_HOME=/usr/lib/jvm/java-7-openjdk-i386 ./build.sh -DskipTests

ビルドが終わったら、以下のようにしてインストール先にバイナリを移動します。

$ mv build/target/wildfly-8.0.0.Alpha1/ /usr/local/jboss/

で、起動

$ cd /usr/local/jboss/wildfly-8.0.0.Alpha1
$  JAVA_HOME=/usr/lib/jvm/java-7-openjdk-i386 ./standalone.sh

 以下が表示されれば起動完了!

15:40:49,486 INFO  [org.jboss.as] (Controller Boot Thread) JBAS015874: WildFly 8.0.0.Alpha1 "WildFly" started in 5917ms - Started 154 of 191 services (57 services are lazy, passive or on-demand)
 

2013年5月9日木曜日

WildFly

とりあえず初めての起動。