使用的是非root用户,下载完毕后,解压完毕后,到bin目录下, 运行run.sh,报如下的错误:
Using PHOENIX_HOME: /usr/local/coolcao/james-2.3.2
Using PHOENIX_TMPDIR: /usr/local/coolcao/james-2.3.2/temp
Using JAVA_HOME: /usr/local/coolcao/jdk1.7.0_45
Running Phoenix:
Phoenix 4.2
James Mail Server 2.3.2
Remote Manager Service started plain:4555
org.apache.avalon.phoenix.containerkit.lifecycle.LifecycleException: Component named "pop3server" failed to pass through the Starting stage. (Reason: Java.NET.BindException: 权限不够).
...
Caused by: java.net.BindException: 权限不够
at java.Net.PlainSocketImpl.socketBind(Native Method)
at java.net.AbstractPlainSocketImpl.bind(AbstractPlainSocketImpl.java:376)
at java.net.ServerSocket.bind(ServerSocket.java:376)
at java.net.ServerSocket.<init>(ServerSocket.java:237)
at org.apache.avalon.cornerstone.blocks.sockets.DefaultServerSocketFactory.createServerSocket(DefaultServerSocketFactory.java:74)
at org.apache.james.core.AbstractJamesService.initialize(AbstractJamesService.java:337)
at org.apache.james.pop3server.POP3Server.initialize(POP3Server.java:116)
at org.apache.avalon.framework.Container.ContainerUtil.initialize(ContainerUtil.java:244)
at org.apache.avalon.phoenix.containerkit.lifecycle.LifecycleHelper.startup(LifecycleHelper.java:200)
... 22 more
主要错误在:Caused by: java.net.BindException: 权限不够
也有说可以使用sudo sh run.sh运行即可
使用sudo sh run.sh后,提示找不到JAVA_HOME
好吧,su切换到root用户,确实找不到JAVA_HOME
在/etc/environment加入java的路径:
使用source /etc/environment刷新一下环境,这下可以找到JAVA_HOME了,使用root切换到james的bin目录再sh run.sh一下,这下就OK 了:
对于这个问题,现在我还没想到更好的解决办法,root的环境变量每次都得设置一下,而且每次启动james都得使用roog用户,这是很不爽的一件事,不知倒大家有没有更好的解决办法,可以教教我。自己再研究两天,看看能不能解决一下,直接使用非root用户启动james。
大概明白了,pop3和smtp服务的端口是110和25,都小于1024,所以,估计因为这样才必须使用root用户才能运行james吧。有大神更好的解决方法吗?