我已经在运行于Google Cloud计算引擎上的Ubuntu计算机上安装了Jenkins。
为此,我运行了以下命令:
sudo apt-get update
sudo apt-get install apache2 libapache2-mod-php5 php5-mcrypt php5-mysql git openjdk-7-jre openjdk-7-jdk -y
wget -q -O - https://pkg.jenkins.io/debian/jenkins-ci.org.key | sudo apt-key add -
sudo sh -c 'echo deb http://pkg.jenkins.io/debian-stable binary/ > /etc/apt/sources.list.d/jenkins.list'
sudo apt-get update
sudo apt-get install jenkins
Jenkins似乎安装得很好,但是当我在端口8080上访问公用IP地址时,那里什么也没有。我读到它可能是因为Apache正在使用端口8080,所以我编辑/etc/default/jenkins
了端口并将其更改为8081。但是,在该端口上我仍然看不到jenkins。
我还重新启动了服务,但没有任何更改。如果我做:
sudo netstat -plntu
我懂了:
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 422/sshd
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 9745/apache2
tcp6 0 0 :::22 :::* LISTEN 422/sshd
tcp6 0 0 :::8081 :::* LISTEN 17917/java
udp 0 0 0.0.0.0:53763 0.0.0.0:* 294/dhclient
udp 0 0 0.0.0.0:68 0.0.0.0:* 294/dhclient
udp 0 0 10.132.0.2:123 0.0.0.0:* 372/ntpd
udp 0 0 127.0.0.1:123 0.0.0.0:* 372/ntpd
udp 0 0 0.0.0.0:123 0.0.0.0:* 372/ntpd
udp6 0 0 :::9732 :::* 294/dhclient
udp6 0 0 :::33848 :::* 17917/java
udp6 0 0 ::1:123 :::* 372/ntpd
udp6 0 0 :::123 :::* 372/ntpd
udp6 0 0 :::5353 :::* 17917/java
如果我检查服务的状态,它似乎正在运行:
[ + ] acpid
[ + ] apache2
[ - ] bootlogs
[ - ] bootmisc.sh
[ - ] checkfs.sh
[ - ] checkroot-bootclean.sh
[ - ] checkroot.sh
[ + ] cron
[ + ] dbus
[ - ] generate-ssh-hostkeys
[ - ] hostname.sh
[ - ] hwclock.sh
[ + ] jenkins
[ - ] killprocs
[ + ] kmod
[ - ] motd
[ - ] mountall-bootclean.sh
[ - ] mountall.sh
[ - ] mountdevsubfs.sh
[ - ] mountkernfs.sh
[ - ] mountnfs-bootclean.sh
[ - ] mountnfs.sh
[ + ] networking
[ + ] ntp
[ + ] procps
[ + ] rc.local
[ - ] rmnologin
[ - ] rsync
[ + ] rsyslog
[ - ] screen-cleanup
[ - ] sendsigs
[ + ] ssh
[ - ] sudo
[ + ] udev
[ + ] udev-finish
[ - ] umountfs
[ - ] umountnfs.sh
[ - ] umountroot
[ - ] unattended-upgrades
[ + ] urandom
[ - ] uuidd
[ - ] x11-common
有人可以告诉我我在做什么错吗?
就VM而言,它看起来Jenkins
确实确实在运行(基于输出netstat
和正在运行的服务列表):
tcp6 0 0 :::8081 :::* LISTEN 17917/java
Jenkins是一个Java应用程序,因此该过程可能仅显示为java
。
看来您正在尝试通过实例的公共IP和端口访问服务。Google Compute Engine(GCE)防火墙可能阻止了此操作,因为默认情况下,GCE
VM中来自外部IP的所有传入端口均被阻止。
如果您的目标是从任何公共IP访问此计算机上的此端口,则可以按照以下步骤授予访问权限:
rules/)
# Create a new firewall rule that allows INGRESS tcp:8081 with VMs containing tag 'allow-tcp-8081'
gcloud compute firewall-rules create rule-allow-tcp-8081 --source-ranges 0.0.0.0/0 --target-tags allow-tcp-8081 --allow tcp:8081
# Add the 'allow-tcp-8081' tag to a VM named VM_NAME
gcloud compute instances add-tags VM_NAME --tags allow-tcp-8081
# If you want to list all the GCE firewall rules
gcloud compute firewall-rules list
Menu -> Networking -> Firewall Rules
Create Firewall Rule
为防火墙规则选择以下设置:
Name
规则- rule-allow-tcp-8081
或您希望此防火墙规则使用的其他任何名称。Direction
是 ingress
Action on match
是 Allow
Targets
是 Specified target tags
Target tags
是 allow-tcp-8081
Source IP ranges
是0.0.0.0/0
(或者如果您有一组IP范围,您知道将是唯一访问此范围的IP范围,请改用它们以提供更严格的限制)Protocols and ports
是 tcp:8081
Create
按钮创建此防火墙规则。创建上述防火墙规则后,您需要将标签添加allow-tcp-8081
到需要应用此规则的所有实例。在您的情况下:
打开GCE VM Instances
页面
VM instance details
页面中,选择Edit
最顶部的链接。Network Tags
框中,输入allow-tcp-8081
以将标签应用于该实例。Save
以保存更改。现在,花几秒钟到几分钟使更改生效,您将能够访问jenkins Web URL。
您还可以浏览 防火墙规则
的文档,以更好地了解它们的工作方式和配置方式。
注意: 通过使用0.0.0.0/0
,您将向整个Internet开放此端口,以便世界各地的客户端都可以连接到该端口。请注意这样做的安全隐患。
我正在使用Jenkins版本1.554.2。我有各种maven项目作业。我最近在Jenkins上创建了一个新的maven作业。它在Jenkins上运行过一次。现在当我点击立即构建时,它只显示工具提示,但不安排构建。我的另一个maven项目运行得很好。 Maven版本:3.2.1Java版本:1.7.0_55 工作类型:maven2/3项目 已安装的插件:
我已经在Ubuntu15.10VM上以单节点模式安装了Hadoop2.6.0。当我使用命令启动Hadoop时,它全部工作,但当我启动Jps命令时,我查看 31602 NameNode 32453 Jps 32169 NodeManager 32045 ResourceManager I报告以下日志文件 不推荐使用此脚本。而是使用start-dfs.sh和start-yarn.sh 在[localh
我在Unix系统(OEL)上安装了一个Jenkins master。我配置了两个通过SSH启动的Unix从机(也是OEL)。从属程序永远不会启动,主程序的GUI中也不会报告错误(根本没有输出,只是一个旋转的球): 我在文件中看到的唯一警告是: 主服务器上的JDK版本是: 从服务器上的Java版本: 看起来Jenkins没有启动任何SSH连接。 将Jenkins升级到1.607版本后,在尝试启动从机
我在服务器上安装了Ubuntu服务器15.04和MariaDB 10.0.17。 安装MariaDB时,我看不到密码设置页面,安装完成。 所以我尝试使用SET password和UPDATE table来更改我的根密码。 但是,没有发生。 我可以使用任何密码和无密码访问MySQL 像这样: 我已经尝试刷新权限;并重新启动mysql服务 重新安装ubuntu,重新安装mariadb。。。等 服务my
问题内容: 如何编写脚本在Ubuntu上安装MySQL服务器? 将安装,但同时还会要求您在控制台中输入密码。 如何以非交互方式进行此操作?也就是说,写一个可以提供密码的脚本吗? 问题答案: 对于特定版本,例如,您需要像这样指定版本: 对于mysql-community-server,密钥略有不同: 将your_password替换为所需的root密码。(似乎your_password也可以留空以获
问题内容: 尽管我相信我正在遵循此处的说明来设置$ httpBackend以将选定的请求传递到服务器,但它对我而言不起作用。 这是一个测试失败的Plunkr, 它显示了我在做什么,并在注释中解释了似乎出错的地方。 我的观点表明,由于某种原因,该模拟没有真实的内部副本,因此,当需要传递XHR请求时,它会将其传递给模拟。第二个调用引发异常,因为它不知道如何处理请求。 对dtabuenc的回应 我很高兴