http://blog.chinaunix.net/uid-25098298-id-287544.html
1. 什么是 java.awt.headless?
Headless模式是系统的一种配置模式。在该模式下,系统缺少了显示设备、键盘或鼠标。
2. 何时使用和headless mode?
Headless模式虽然不是我们愿意见到的,但事实上我们却常常需要在该模式下工作,尤其是服务器端程序开发者。因为服务器(如提供Web服务的主机)往往可能缺少前述设备,但又需要使用他们提供的功能,生成相应的数据,以提供给客户端(如浏览器所在的配有相关的显示设备、键盘和鼠标的主机)。
3. 如何使用和Headless mode?
一般是在程序开始激活headless模式,告诉程序,现在你要工作在Headless mode下,就不要指望硬件帮忙了,你得自力更生,依靠系统的计算能力模拟出这些特性来:
System.setProperty("java.awt.headless", "true");
4. 测试程序:
- import java.awt.Graphics;
- import java.awt.image.BufferedImage;
- import java.io.File;
- import javax.imageio.ImageIO;
- public class TestCHSGraphic{
-
- public static void main(String[] args) throws Exception{
- //设置Headless模式
- System.setProperty("java.awt.headless", "true");
- BufferedImage bi = new BufferedImage(200, 100, BufferedImage.TYPE_INT_RGB);
- Graphics g = bi.getGraphics();
- String s = "Headless模式测试";
- g.drawString(new String(s.getBytes(), "GB2312"), 50, 50);
- ImageIO.write(bi, "jpeg", new File("test.jpg"));
- }
-
- }
5. Toolkit类的getDefaultToolkit函数api中文说明
public static Toolkit getDefaultToolkit()获取默认工具包。如果名为 "java.awt.headless" 的系统属性被设置为 true,则使用 Toolkit 的 headless 实现。如果不存在 "java.awt.headless" 或 "java.awt.headless" 被设置为 false,且存在名为 "awt.toolkit" 的系统属性,则该属性将被视为 Toolkit 子类的名称;否则将使用特定于平台的默认 Toolkit 实现。还可以使用 Sun 引用实现中指定的属性 'assistive_technologies' 将其他类加载到 VM 中,该属性是在 'accessibility.properties' 文件的一个行中指定的。形式是 "assistive_technologies=...",其中 "..." 是以逗号分隔的、要加载的辅助技术类的列表。每个类都以给定的顺序加载,并且要使用 Class.forName(class).newInstance() 创建每个类的单独实例。此操作在创建 AWT 工具包之后进行。所有错误都通过 AWTError 异常来处理。 返回: 默认工具包。 抛出: AWTError - 如果不能找到工具包,或者不能访问或实例化工具包。
参考: http://hi.baidu.com/lovemywolf/blog/item/be08ebed2293734979f05595.html
jdk api 文档
- tomcat X connection to localhost:11.0 broken (2010-12-31 23:51:18)
- AIX上websphere6.1发布应用程序后显示中文乱码问题 (2011-01-01 16:27:56)
- Robotium 只有apk测试 通过id获取view (32分钟前)
- JavaScript语句后应该加分号么? (1小时前)
- jquery的uploadify上传jsp+servlet (2小时前)
- =================
http://leshazlewood.com/2009/08/26/linux-javaawtheadless-and-the-display-environment-variable/
Just a quick note to self:
After looking at the JDK source code today, we found that even when setting -Djava.awt.headless=true
, if a script executes with the DISPLAY
environment variable set, the AWT graphics environment will still use a GraphicsEnvironment representing that DISPLAY
.
A major problem with this is if the shell that launched the script that started the java process ever executes, the GraphicsEnvironment reflecting the DISPLAY will be removed and any Object instances reflecting that environment would be invalidated or Classes once available will no longer be available. resulting in a NoClassDefFoundException.
Bottom line: on Linux, if setting -Djava.awt.headless=true
in a script, ensure that you unset DISPLAY
in the script before starting the java
process. It will save some headaches in debugging.
==============https://confluence.atlassian.com/plugins/viewsource/viewpagesrc.action?pageId=133693889
When attempting to use a Chart either with the Chart Plugin (JIRA 3.13) or the Pie Chart Gadget (4.0+), no output is rendered. Errors like the following appear in the logs:
2008-02-04 12:45:36,051 TP-Processor6 ERROR [500ErrorPage] Exception caught in 500 page /usr/local/java/jdk1.6.0_02/jre/lib/i386/xawt/libmawt.so: libXtst.so.6: cannot open shared object file: No such file or directory java.lang.UnsatisfiedLinkError: /usr/local/java/jdk1.6.0_02/jre/lib/i386/xawt/libmawt.so: libXtst.so.6: cannot open shared object file: No such file or directory at java.lang.ClassLoader$NativeLibrary.load(Native Method) at java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1751) at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1647) at java.lang.Runtime.load0(Runtime.java:770) at java.lang.System.load(System.java:1005) at java.lang.ClassLoader$NativeLibrary.load(Native Method) at java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1751) at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1668) at java.lang.Runtime.loadLibrary0(Runtime.java:823) at java.lang.System.loadLibrary(System.java:1030) at sun.security.action.LoadLibraryAction.run(LoadLibraryAction.java:50) at java.security.AccessController.doPrivileged(Native Method) at java.awt.Toolkit.loadLibraries(Toolkit.java:1594) at java.awt.Toolkit.<clinit>(Toolkit.java:1616) at java.awt.Color.<clinit>(Color.java:263) at com.atlassian.jira.ext.charting.jfreechart.ChartUtils.<clinit>(ChartUtils.java:45) at com.atlassian.jira.ext.charting.data.DataCollector.populatePieChart(DataCollector.java:669) at com.atlassian.jira.ext.charting.charts.singlefieldpie.SingleFieldPieChart.getViewHtml(SingleFieldPieChart.java:57) at com.atlassian.jira.ext.charting.charts.PortletSearchView.writeSearchResults(PortletSearchView.java:89) |
In addition, errors like the following appear:
2008-02-04 12:49:14,654 TP-Processor2 ERROR [webwork.dispatcher.ServletDispatcher] Could not execute action java.lang.NoClassDefFoundError: Could not initialize class com.atlassian.jira.ext.charting.jfreechart.ChartUtils at com.atlassian.jira.ext.charting.data.DataCollector.retrieveOrMakeSearchRequest(DataCollector.java:205) |
Cause
Charts that create custom graphics require X11 libraries and an X11 session to assist in creating their output.
Resolution
|
Related Content
|
|
{htmlcomment} Regular Expression: java.lang.NoClassDefFoundError: Could not initialize class com.atlassian.jira.ext.charting.jfreechart.ChartUtils http://support.atlassian.com/browse/JSP-19704 {htmlcomment} |