centos 运行java程序(centos远程桌面软件)
老铁们,大家好,相信还有很多朋友对于centos 运行java程序和centos远程桌面软件的相关问题不太懂,没关系,今天就由我来为大家分享分享centos 运行java程序以及centos远程桌面软件的问题,文章篇幅可能偏长,希望可以帮助到大家,下面一起来看看吧!
【UTC】CentOS7修改时区的正确姿势
整个地球分为二十四时区,每个时区都有自己的本地时间。在国际无线电通信场合,为了统一起见,使用一个统一的时间,称为通用协调时(UTC,Universal Time Coordinated)。
格林威治标准时间(Greenwich Mean Time)指位于英国伦敦郊区的皇家格林尼治天文台的标准时间,因为本初子午线被定义在通过那里的经线。(UTC与GMT时间基本相同,本文中不做区分)
中国标准时间(China Standard Time)【GMT + 8 = UTC + 8 = CST】
夏令时(Daylight Saving Time)指在夏天太阳升起的比较早时,将时钟拨快一小时,以提早日光的使用。(中国不使用)
RTC(Real-Time Clock)或CMOS时钟,一般在主板上靠电池供电,服务器断电后也会继续运行。仅保存日期时间数值,无法保存时区和夏令时设置。
一般在服务器启动时复制RTC时间,之后独立运行,保存了时间、时区和夏令时设置。
在CentOS 6版本,时间设置有date、hwclock命令,从CentOS 7开始,使用了一个新的命令timedatectl。
Centos7修改系统时区timezone ,解决快、慢8小时问题
如果服务器用非 UTC的时间,时区转换很容易不一致,而且对于有 daylight saving的时区,每年多一小时少一小时的那两天,系统就会出现各种诡异现象。
服务器使用UTC时间,如要显示用户所在时区的本地时间,在客户端转化即可。
# timedatectl
我们可以看到,服务器使用的CST时间
# timedatectl set-timezone UTC
# timedatectl set-time"YYYY-MM-DD HH:MM:SS"
# timedatectl set-time "HH:MM:SS"
# timedatectl
我们可以看到,服务器时间类型更改为UTC了
# ll /etc/locatime
lrwxrwxrwx. 1 root root 25 1月 14 08:30 /etc/localtime->../usr/share/zoneinfo/UTC
实际上是做了一个将
文件 /etc/localtime 做了一个软连接到 /usr/share/zoneinfo/UTC
# ln -s /usr/share/zoneinfo/UTC /etc/localtime
ln:无法创建符号链接"/etc/localtime":文件已存在
# ln -sf /usr/share/zoneinfo/UTC /etc/localtime
做软连接时,需要加-f参数,强制覆盖,不然会显示软链接已存在
# timedatectl set-time"YYYY-MM-DD HH:MM:SS"
# timedatectl set-time "HH:MM:SS" //只设置时分秒
# timedatectl
# clock -w
# date -u //显示UTC时间
CentOS7修改时区的正确姿势
CentOS7上运行Java程序,发现程序生成的时间与当前时间匹配不上,还以为是数据停止更新了,后来发现没有正确使用修改时区的姿势,导致程序时区错误。
正确的修改CentOS7时区的姿势:
# ln -sf/usr/share/zoneinfo/Asia/Shanghai /etc/localtime
其他系统的修改文件可能是/var/etc/localtime.
错误的姿势:通过cp命令覆盖/etc/localtime时间
# cp-f /usr/share/zoneinfo/Asia/Shanghai /etc/localtime
通过cp命令修改时区,通过date, data-R命令显示的时区都是正确的,可是对于java程序而言,是错误的。
具体原因在于Java访问系统时区的方式上,可参见文章:
Java TimeZone和 Linux TimeZone问题
该文章很好的说明了Java访问系统时区的方式:
1.如有环境变量 TZ设置,则用TZ中设置的时区
2.在/etc/sysconfig/clock文件中找“ZONE”的值
3.如何2)都没,就用/etc/localtime和/usr/share/zoneinfo下的时区文件进行匹配,如找到匹配的,就返回对应的路径和文件名。
问题在于,如果使用cp命令来修改/etc/localtime文件,那么可能就会导致修改的不是/etc/localtime文件,而是原时区的文件内容。
/etc/localtime是通过符号链接链接/usr/share/zoneinfo下的文件,而java是通过文件名来确认时区的,data命令是通过文件内容确认时区的,这样就导致了data命令时区正确,而java的时区是错误的!
如上图所示:CentOS7是通过符号链接到/usr/share/zoneinfo/下的时区文件的,如果通过cp指令只会修改原时区文件内容,这样,通过date的系统命令,查看时间是OK的,可是java是通过读取文件名的方式确认时区信息的。所以时区还是纽约。
学习如何使用Linux环境运行Java程序linux下的java
Linux是世界上最受欢迎的操作系统之一,也是免费、开放源代码的操作系统。它非常受欢迎,在企业服务器、超级计算机和家庭用户的计算机上都很常见。它可以用来开发各种种类的应用程序,比如Java程序。本文将介绍如何使用Linux环境来运行Java程序。
首先,您需要安装一个最新版本的Java虚拟机(JVM),以便运行Java程序。安装Java虚拟机可以通过使用Linux上的包管理器进行。 Debian/Ubuntu和Fedora/CentOS上有不同的包管理器可以使用,请找到一个合适的。
安装完JVM之后,您应该在/usr/bin目录中找到Java程序的命令行。接下来,您需要编译Java源代码并生成可执行的Java类文件。您可以使用javac编译器来完成此操作。您可以通过输入以下命令来编译Java源代码:
“`javac filename.java“`
这将生成一个名为filename.class的可执行文件,这就是您需要运行Java程序的文件。最后,您可以使用“java”命令行工具来运行Java类文件:
“`java filename“`
这将启动文件中定义的Java应用程序。您可以使用以上步骤在Linux环境中轻松地运行Java程序。
总之,学习如何在Linux环境中运行Java程序非常有用。首先,您需要安装一个最新版本的Java虚拟机。然后,您需要编译Java源代码并生成可执行的Java类文件。最后,您可以使用“java”命令行工具来运行Java类文件。使用这些步骤,您可以轻松地在Linux环境中运行Java程序。
centos java进程 怎么被启动的
1.查进程
ps命令查找与进程相关的PID号:
ps a显示现行终端机下的所有程序,包括其他用户的程序。
ps-A显示所有程序。
ps c列出程序时,显示每个程序真正的指令名称,而不包含路径,参数或常驻服务的标示。
ps-e此参数的效果和指定"A"参数相同。
ps e列出程序时,显示每个程序所使用的环境变量。
ps f用ASCII字符显示树状结构,表达程序间的相互关系。
ps-H显示树状结构,表示程序间的相互关系。
ps-N显示所有的程序,除了执行ps指令终端机下的程序之外。
ps s采用程序信号的格式显示程序状况。
ps S列出程序时,包括已中断的子程序资料。
ps-t<终端机编号>指定终端机编号,并列出属于该终端机的程序的状况。
ps u以用户为主的格式来显示程序状况。
ps x显示所有程序,不以终端机来区分。
最常用的方法是ps aux,然后再通过管道使用grep命令过滤查找特定的进程,然后再对特定的进程进行操作。
ps aux| grep program_filter_word,ps-ef|grep tomcat
ps-ef|grep java|grep-v grep显示出所有的java进程,去处掉当前的grep进程。
2.杀进程
使用kill命令结束进程:kill xxx
常用:kill-9 324
Linux下还提供了一个killall命令,可以直接使用进程的名字而不是进程标识号,例如:# killall-9 NAME
3.进入到进程的执行文件所在的路径下,执行文件./文件名
附:
这是本人花了两天时间整理得来的,一些最常用的地球人都知道的命令就省去啦!最后提供pdf手册下载
1.更改档案拥有者
命令: chown [-cfhvR] [--help] [--version] user[:group] file...
功能:更改文件或者文件夹的拥有者
参数格式:
user:新的档案拥有者的使用者 IDgroup:新的档案拥有者的使用者群体(group)
-c:若该档案拥有者确实已经更改,才显示其更改动作
-f:若该档案拥有者无法被更改也不要显示错误讯息
-h:只对于连结(link)进行变更,而非该 link真正指向的档案
-v:显示拥有者变更的详细资料
-R:对目前目录下的所有档案与子目录进行相同的拥有者变更(即以递回的方式逐个变更)
例如:chown-R oracle:oinstall/oracle/u01/app/oracle
更改目录拥有者为oracle
2.修改权限
命令:chmod(change mode)
功能:改变文件的读写和执行权限。有符号法和八进制数字法。
选项:(1)符号法:
命令格式:chmod{u|g|o|a}{+|-|=}{r|w|x} filename
u(user)表示用户本人。
g(group)表示同组用户。
o(oher)表示其他用户。
a(all)表示所有用户。
+用于给予指定用户的许可权限。
-用于取消指定用户的许可权限。
=将所许可的权限赋给文件。
r(read)读许可,表示可以拷贝该文件或目录的内容。
w(write)写许可,表示可以修改该文件或目录的内容。
x(execute)执行许可,表示可以执行该文件或进入目录。
(2)八进制数字法:
命令格式:chmod abc file
其中a,b,c各为一个八进制数字,分别表示User、Group、及Other的权限。
4(100)表示可读。
2(010)表示可写。
1(001)表示可执行。
若要rwx属性则4+2+1=7;
若要rw-属性则4+2=6;
若要r-x属性则4+1=5。
例如:# chmod a+rx filename
让所有用户可以读和执行文件filename。
# chmod go-rx filename
取消同组和其他用户的读和执行文件filename的权限。
# chmod 741 filename
让本人可读写执行、同组用户可读、其他用户可执行文件filename。
# chmod-R 755/home/oracle
递归更改目录权限,本人可读写执行、同组用户可读可执行、其他用户可读可执行
3.修改文件日期
命令:touch
格式:touch filenae
功能:改变文件的日期,不对文件的内容做改动,若文件不存在则建立新文件。
例如:% touch file
4.链接文件
命令:ln(link)
格式:ln [option] filename linkname
ln [option] directory pathname
功能:为文件或目录建立一个链。其中,filename和directory是源文件名和
源目录名;linkname和pathname分别表示与源文件或源目录名相链接的
文件或目录。
选项:-s为文件或目录建立符号链接。不加-s表示为文件或目录建立硬链接
注释:链接的目地在于,对一个文件或目录赋予两个以上的名字,使其可以出
现在不同的目录中,既可以使文件或目录共享,又可以节省磁盘空间。
例如:% ln-s filename linkname
5.显示日期
命令:date
例如:% date
6.显示日历
命令:cal(calendar)
格式:cal [month] year
功能:显示某年内指定的日历
例如:% cal 1998
7.显示文件头部
命令:head
格式:head [option] filename
功能:显示文件的头部
选项:缺省显示文件的头10行。
-i显示文件的开始 i行。
例如:% head filename
8.显示文件尾部
命令:tail
格式:tail [option] filename
功能:显示文件的尾部
选项:缺省显示文件的末10行。
-i显示文件最后 i行。
+i从文件的第i行开始显示。
例如:% tail filename
9.显示用户标识
命令:id
格式:id [option] [user]
功能:显示用户标识及用户所属的所有组。
选项:-a显示用户名、用户标识及用户所属的所有组
注释:
例如:% id username
10.查看当前登录的用户
命令:users
11.显示都谁登录到机器上
命令:who
格式:who
功能:显示当前正在系统中的所有用户名字,使用终端设备号,注册时间。
例如:% who
12.显示当前终端上的用户名
命令:whoami
格式:whoami
功能:显示出当前终端上使用的用户。
例如:% whoami
13.寻找文件
命令:find
格式:find pathname [option] expression
功能:在所给的路经名下寻找符合表达式相匹配的文件。
选项:-name表示文件名
-user用户名,选取该用户所属的文件
-size按大小查找,以block为单位,一个block是512B
-mtime n按最后一次修改时间查找,选取n天内被修改的文件
-perm按权限查找
-type按文件类型查找
-atime按最后一次访问时间查找
例如:% find./-name'*abc*'-print
14.搜索文件中匹配符
命令:grep
格式:grep [option] pattern filenames
功能:逐行搜索所指定的文件或标准输入,并显示匹配模式的每一行。
选项:-i匹配时忽略大小写
-v找出模式失配的行
例如:% grep-i'java*'./test/run.sh
15.统计文件字数
命令:wc [option] filename
功能:统计文件中的文件行数、字数和字符数。
选项:-l统计文件的行数
-w统计文件的单词数
-c统计文件的字符数
注释:若缺省文件名则指标准输入
例如:% wc-c./test/run.sh
16.显示磁盘空间
命令:df(disk free)
格式:df [option]
功能:显示磁盘空间的使用情况,包括文件系统安装的目录名、块设备名、总
字节数、已用字节数、剩余字节数占用百分比。
选项:
-a:显示全部的档案系统和各分割区的磁盘使用情形
-i:显示i-nodes的使用量
-k:大小用k来表示(默认值)
-t:显示某一个档案系统的所有分割区磁盘使用量
-x:显示不是某一个档案系统的所有分割区磁盘使用量
-T:显示每个分割区所属的档案系统名称
-h:表示使用「Human-readable」的输出,也就是在档案系统大小使用 GB、MB等易读的格式。
注释:
例如:% df-hi
17.查询档案或目录的磁盘使用空间
命令:du(disk usage)
格式:du [option] [filename]
功能:以指定的目录下的子目录为单位,显示每个目录内所有档案所占用的磁盘空间大小
选项:
-a:显示全部目录和其次目录下的每个档案所占的磁盘空间
-b:大小用bytes来表示(默认值为k bytes)
-c:最后再加上总计(默认值)
-s:只显示各档案大小的总合
-x:只计算同属同一个档案系统的档案
-L:计算所有的档案大小
-h:表示档案系统大小使用 GB、MB等易读的格式。
例如:% du-a
% du-sh/etc只显示该目录的总合
% du/etc| sort-nr| more统计结果用sort指令进行排序,
sort的参数-nr表示要以数字排序法进行反向排序。
18.显示进程
命令:ps
格式:ps [option]
功能:显示系统中进程的信息。包括进程ID、控制进程终端、执行时间和命令。
选项:
-a显示所有进程信息
-U uidlist列出这个用户的所有进程
-e显示当前运行的每一个进程信息
-f显示一个完整的列表
-x显示包括没有终端控制的进程状况。
注释:
例如:% ps-ef
% ps-aux然后再利用一个管道符号导向到grep去查找特定的进程,然后再对特定的进程进行操作。
19.终止进程
命令:kill
格式:kill [option] pid
功能:向指定的进程送信号或终止进程。kill指令的用途是送一个signal给某一个process,
因为大部份送的都是用来杀掉 process的 SIGKILL或 SIGHUP,因此称为 kill
选项:-9强行终止进程
注释:pid标示进程号,可由ps命令得到。
例如:% kill-9 pid
你也可以用 kill-l来察看可代替 signal号码的数目字。kill的详细情形请参阅 man kill。
20.查看自己的IP地址
命令:ifconfig
格式:ifconfig-a
21.查看路由表
命令:netstat
格式:netstat-rn
22.远程登录
命令:telnet
格式:telnet hostname
23.文件传输
命令:ftp(file transfer program)
格式:ftp hostname
功能:网络文件传输及远程操作。
选项:ftp命令:
cd [dirname]进入远程机的目录
lcd [dirname]设置本地机的目录
dir/ls显示远程的目录文件
bin以二进制方式进行传输
asc以文本文件方式进行传输
get/mget从远程机取一个或多个文件
put/mput向远程机送一个或多个文件
prompt打开或关闭多个文件传送时的交互提示
close关闭与远程机的连接
quit退出ftp
!/exit ftp登陆状态下,!表示暂时退出ftp状态回到本地目录,exit表示返回ftp状态
注释:
例如:% ftp hostname
24.查看自己的电子邮件
命令:mailx
格式:mailx
选项:
delete删除
next下一个
quit退出
reply回复
25.回忆命令
命令:history
格式:history
功能:帮助用户回忆执行过的命令。
选项:
注释:
例如:% history
26.网上对话
命令:talk
格式:talk username
功能:在网上与另一用户进行对话。
选项:
注释:对话时系统把终端分为上下两部分,上半部显示自己键入信息,下半部
显示对方用户键入的信息。键入delete或Ctrl+C则结束对话。
例如:% talk username
27.允许或拒绝接受信息
命令:mesg(message)
格式:mesg [n/y]
功能:允许或拒绝其它用户向自己所用的终端发送信息。
选项:n拒绝其它用户向自己所用的终端写信息
y允许其它用户向自己所用的终端写信息(缺省值)
注释:
例如:% mesg n
28.给其他用户写信息
命令:write
格式:write username [ttyname]
功能:给其他用户的终端写信息。
选项:
注释:若对方没有拒绝,两用户可进行交谈,键入EOF或Ctrl+C则结束对话。
例如:write username
29.创建、修改、删除用户和群组
a.创建群组:
例如: groupadd oinstall创建群组名为oinstall的组
groupadd-g 344 dba
创建组号是344的组,此时在/etc/passwd文件中产生一个组ID(GID)是344的项目。
b.修改群组:
groupmod:该命令用于改变用户组帐号的属性
groupmod–g新的GID用户组帐号名
groupmod–n新组名原组名:此命令由于改变用户组的名称
c.删除群组:
groupdel组名:该命令用于删除指定的组帐号
d.新建用户:
命令: useradd [-d home] [-s shell] [-c comment] [-m [-k template]]
[-f inactive] [-e expire ] [-p passwd] [-r] name
主要参数
-c:加上备注文字,备注文字保存在passwd的备注栏中。
-d:指定用户登入时的启始目录。
-D:变更预设值。
-e:指定账号的有效期限,缺省表示永久有效。
-f:指定在密码过期后多少天即关闭该账号。
-g:指定用户所属的群组。
-G:指定用户所属的附加群组。
-m:自动建立用户的登入目录。
-M:不要自动建立用户的登入目录。
-n:取消建立以用户名称为名的群组。
-r:建立系统账号。
-s:指定用户登入后所使用的shell。
-u:指定用户ID号。
举例:# useradd-g oinstall-G dba oracle创建Oracle用户
e.删除用户
命令: userdel用户名
删除指定的用户帐号
userdel–r用户名(userdel用户名;rm用户名):删除指定的用户帐号及宿主目录
例:#useradd-g root kkk//把kkk用户加入root组里
f.修改用户
命令: usermod
修改已有用户的信息
usermod–l旧用户名新用户名:修改用户名
usermod–L用户名:用于锁定指定用户账号,使其不能登陆系统
usermod–U用户名:对锁定的用户帐号进行解锁
passwd–d用户名:使帐号无口令,即用户不需要口令就能登录系统
例:#usermod-l user2 user1//把用户user2改名为user1
30.启动、关闭防火墙
永久打开或则关闭
chkconfig iptables on
chkconfig iptables off
即时生效:重启后还原
service iptables start
service iptables stop
或者:
/etc/init.d/iptables start
/etc/init.d/iptables stop
31.启动VSFTP服务
即时启动:/etc/init.d/vsftpd start
即时停止:/etc/init.d/vsftpd stop
开机默认VSFTP服务自动启动:
方法一:(常用\方便)
[root@localhost etc]# chkconfig--list|grep vsftpd(查看情况)
vsftpd 0:off 1:off 2:off 3:off 4:off 5:off 6:off
[root@localhost etc]# chkconfig vsftpd on(执行ON设置)
或者:方法二:
修改文件/etc/rc.local,把行/usr/local/sbin/vsftpd&插入文件中,以实现开机自动启动。