小编jsi*_*sky的帖子

Eclipse可以将Maven Web项目导入为"动态Web应用程序"吗?

高级目标:创建一个可在Netbeans和Eclipse中正确使用的Maven Web应用程序项目

将Maven项目转换为Eclipse时,使用该命令时,项目类型似乎不会设置为Dynamic Web App:mvn eclipse:eclipse -Dwtpversion = 2.0

在Eclipse中,如果创建动态Web应用程序,Project Explorer中会显示更多选项,例如: JAX-WS Web服务,部署描述符等. 这是一个完全不同的框架结构.

在此输入图像描述

此外,在使用上述命令转换为Eclipse之后,即使转换的输出显示:[INFO]使用作为WTP服务器:Apache Tomcat v7.0,我也无法"运行"它.它不是想要作为Web服务运行,而是询问我这是Java Servlet,Applet还是Unit测试.

在此输入图像描述

使用动态Web应用程序(本机Eclipse),这是运行项目时显示的内容:

在此输入图像描述

也许我对Eclipse的要求太高了,为了获得内置的Web应用程序功能,它不能来自Maven?

还有一个我可以试试的.我可以在Eclipse中创建一个Dynamic Web App,然后点击"Convert to Maven".拿那个POM,修改,然后看看netbeans是否也会加载它.

我的'pom.xml':

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
     xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>

<groupId>com.voxel</groupId>
<artifactId>servermap</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>

<name>userprofile</name>

<properties>
    <endorsed.dir>${project.build.directory}/endorsed</endorsed.dir>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>

<dependencies>
    <dependency>
        <groupId>javax</groupId>
        <artifactId>javaee-web-api</artifactId>
        <version>6.0</version>
        <scope>provided</scope>
    </dependency>

    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.8.2</version>
        <scope>test</scope>
    </dependency>

    <dependency>
        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-server</artifactId>
        <version>1.8</version>
    </dependency>
    <dependency>
        <groupId>com.sun.grizzly</groupId>
        <artifactId>grizzly-servlet-webserver</artifactId>
        <version>1.9.18-m</version>
    </dependency>
</dependencies>

<repositories>
    <repository>
        <id>maven2-repository.dev.java.net</id>
        <name>Java.net Repository for Maven</name>
        <url>http://download.java.net/maven/2</url>
    </repository>
</repositories>
Run Code Online (Sandbox Code Playgroud)

eclipse jersey maven

16
推荐指数
1
解决办法
1万
查看次数

可以在MySQL的BEFORE TRIGGER中安全地使用AUTO_INCREMENT

Instagram的Postgres为Sharding实现自定义ID的方法很棒,但我需要在MySQL中实现.

所以,我转换了这个博客底部的方法,在这里:http://instagram-engineering.tumblr.com/post/10853187575/sharding-ids-at-instagram

MySQL版本:

CREATE TRIGGER shard_insert BEFORE INSERT ON tablename
FOR EACH ROW BEGIN

DECLARE seq_id BIGINT;
DECLARE now_millis BIGINT;
DECLARE our_epoch BIGINT DEFAULT 1314220021721;
DECLARE shard_id INT DEFAULT 1;

SET now_millis = (SELECT UNIX_TIMESTAMP(NOW(3)) * 1000);
SET seq_id = (SELECT AUTO_INCREMENT FROM information_schema.TABLES WHERE TABLE_SCHEMA = "dbname" AND TABLE_NAME = "tablename");
SET NEW.id = (SELECT ((now_millis - our_epoch) << 23) | (shard_id << 10) | (SELECT MOD(seq_id, 1024)));
END
Run Code Online (Sandbox Code Playgroud)

该表看起来大致如下:

CREATE TABLE tablename (
    id BIGINT …
Run Code Online (Sandbox Code Playgroud)

mysql triggers sharding auto-increment instagram

10
推荐指数
1
解决办法
1218
查看次数

对于Java中的RESTful服务,JAX-RS是否比Swing,Grails或Play等MVC框架更好?

例如,Play-framework支持这样的RESTful服务:RESTful on Play!骨架

这与Jax-RS Jersey实施相比如何?像Play这样的框架是否会在泽西岛附近运行,因为它的所有功能都很酷,而且它也有REST吗?

开发人员的工作效率很重要,但正确的实现也是如此.也许使用MVC框架仅用于REST服务是"错误的"?

请注意,只有RESTful服务,根本没有UI组件.

rest grails jax-rs jersey playframework

8
推荐指数
2
解决办法
6166
查看次数

MySQL 5.6.19 TIMESTAMP 不能接受很多正确的值

我遇到了一个非常奇怪的问题,不明白这一点。

CREATE TABLE test (time TIMESTAMP NOT NULL DEFAULT NOW()) ENGINE=INNODB;

mysql> insert into test (time) values("2011-03-13 01:08:04");
Query OK, 1 row affected (0.00 sec)
Run Code Online (Sandbox Code Playgroud)

这很好。现在,仅将时间更改 1 小时:

mysql> insert into test (time) values("2011-03-13 02:08:04");
ERROR 1292 (22007): Incorrect datetime value: '2011-03-13 02:08:04' for column 'time' at row 1
Run Code Online (Sandbox Code Playgroud)

这里发生了什么?我随机插入日期时间值并发现许多值无法插入:“2011-03-13 02:08:04”、“2010-03-14 02:04:05”、“2009-03-08 02” :24:52", "2009-03-08 02:48:27", "2011-03-13 02:06:01", "2005-04-03 02:00:44"...

将小时更改为 1 或将年份更改为 1 可以解决问题,但当然不是真正的解决方法。

mysql datetime timestamp mysql-5.6

3
推荐指数
1
解决办法
1822
查看次数