6

我正在尝试在 GAE 中进行一些简单的登录,但我认为我一定错过了一些简单的步骤。

我已按照此处的说明进行操作:https ://developers.google.com/appengine/docs/java/runtime#Logging

我希望在日志中写一条简单的消息,如下所示:

public class InsertServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;
    private static final Logger log = Logger.getLogger(InsertServlet.class.getName());

    public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {

            log.info("Handled GET request - custom message");
            resp.setContentType("text/plain");
            resp.getWriter().println("HELLO");

    }

}

如果我使用网络浏览器访问我的应用程序,我可以看到它正在运行(在浏览器中获得“HELLO”消息)。

但是在此之后,如果我访问控制台中的日志,我可以看到它正在记录事件,但我在任何地方都看不到我的消息。

我选择了“显示:所有请求”,但这是我访问后在日志中看到的全部内容:

012-08-19 13:34:56.488 /插入 200 2922ms 0kb Mozilla/5.0 (Windows NT 6.1; WOW64; rv:14.0) Gecko/20100101 Firefox/14.0.1

2602:306:ce97:de40:8dbd:ace7:14c3:89e2 - - [19/Aug/2012:13:34:56 -0700]“获取/插入 HTTP/1.1”200 52 -“Mozilla/5.0(Windows NT 6.1; WOW64; rv:14.0) Gecko/20100101 Firefox/14.0.1" "karwosts-helloworld.appspot.com" ms=2923 cpu_ms=1213 api_cpu_ms=0 cpm_usd=0.000006 loading_request=1 instance=00c61b117cf339fa358dc21f7f91a

我 2012-08-19 13:34:56.487

此请求导致为您的应用程序启动一个新进程,从而导致您的应用程序代码首次加载。因此,与您的应用程序的典型请求相比,此请求可能需要更长的时间并使用更多的 CPU。

Logging.Properties(只有一行):

.level = WARNING

appengine-web.xml

<?xml version="1.0" encoding="utf-8"?>
<appengine-web-app xmlns="http://appengine.google.com/ns/1.0">
  <application>karwosts-helloworld</application>
  <version>1</version>

  <threadsafe>true</threadsafe>

  <!-- Configure java.util.logging -->
  <system-properties>
    <property name="java.util.logging.config.file" value="WEB-INF/logging.properties"/>
  </system-properties>

</appengine-web-app>

log.info我的自定义字符串在哪里?我没有找对地方吗?

4

2 回答 2

9

乍一看,我会说当您在“logging.properties”文件中使用此设置时:

.level = WARNING

而且,您(在登录代码时不指定任何级别,将使用默认级别,这肯定不是“警告”(我猜 INFO ^^) 确实使用此行指定日志级别:

log.info(msg);

/* which is same as */
log.log(Level.INFO, msg);

所以结果是你只在'INFO'级别(在你的例子中)登录,但你的配置文件说要在 WARNING 及以上级别登录。由于“信息”级别低于“警告”,它们将从您的日志文件中丢弃,并且不会显示在您的服务器日志中。

我建议改用这种方法,它会强制您指定日志记录级别。

import java.util.logging.Level;
import java.util.logging.Logger;
/* ... */
log.log(Level.INFO, "a info msg"); //info
log.log(Level.WARNING, "a warning msg"); //warning
log.log(Level.FINEST, "a fine(st) msg"); //debug (as finest)

之后,您可以使用logging.properties文件为所需的类设置所需的日志记录级别:

# Set the default logging level for all loggers to WARNING
.level = WARNING

# Set level for your app
oed.server.level = INFO
oed.server.data.datastore.myInjector.level = FINEST

Edit2 : 此日志记录配置在客户端运行时没有影响。当你想在 GWT 中记录消息时,有 this GWT.log(message);,但不能指定级别。

这并不完全正确,这取决于your-app.gwt.xml文件中的配置。所有详细信息都可以在google dev guilde logging上找到。我发现它非常有用并且做得很好。尽管如此,简而言之,GWT 中有各种默认记录器(大约 5-6 个);所有这些都可以*.gwt.xml通过它们的处理程序进行配置(或者可以务实地完成)。在侵入性弹出记录器存在太久之后......我选择从客户端远程登录到服务器以享受使用logging.properties,这里是使用时的配置gwt.xml

<!-- Logging configuration -->
  <inherits name="com.google.gwt.logging.Logging"/>

  <set-property name="gwt.logging.logLevel" value="INFO"/>  <!-- # To change the default logLevel -->
  <set-property name="gwt.logging.enabled" value="TRUE"/>  
  <set-property name="gwt.logging.simpleRemoteHandler" value="ENABLED" /> <!-- Remote logging (linked with servlet) -->
  <set-property name="gwt.logging.popupHandler" value="DISABLED" />
  <set-property name="gwt.logging.developmentModeHandler" value="ENABLED" />  
  <set-property name="gwt.logging.systemHandler" value="ENABLED" />
  <set-property name="gwt.logging.firebugHandler" value="DISABLED" />
  <set-property name="gwt.logging.consoleHandler" value="ENABLED"/>

如果您使用此设置,请不要忘记web.xml使用 servlet 定义来配置您的日志记录(遗憾的是,文档中没有提供):

<servlet>
        <servlet-name>remoteLogging</servlet-name>
        <servlet-class>com.google.gwt.logging.server.RemoteLoggingServiceImpl</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>remoteLogging</servlet-name>
        <url-pattern>/your-app-name/remote_logging</url-pattern>
    </servlet-mapping>

祝你好运 !

于 2012-08-20T11:28:24.020 回答
0

而不是检查“所有请求”,您应该检查“具有最低严重性的日志”并从下拉列表中选择“信息”。

于 2012-08-20T00:45:35.967 回答