1

我目前通過GCE書架教程,這是給我最頭痛的工作:https://cloud.google.com/nodejs/tutorials/bookshelf-on-compute-engineGoogle Compute Engine Bookshelf教程:npm ERR!網絡閱讀ECONNRESET

我卡在這一步:

To see the application running, go to http://[YOUR_INSTANCE_IP]:8080, 

where [YOUR_INSTANCE_IP] is the external IP address of your instance. 

當我嘗試查看我的應用程序通過端口8080我的外部IP,沒有任何反應。

我可以證實,防火牆規則正確與我的虛擬機實例顯示正確的網絡標籤應用。

我通過串行日誌去了,這才意識到出事了,在該實例無法克隆Git倉庫的啓動腳本。

因此,我改變

git clone https://source.developers.google.com/p/$PROJECTID /opt/app

git clone https://source.developers.google.com/p/d3-barchart/r/repo /opt/app

(REST的startup-script.sh在這裏:)

#! /bin/bash 
# Copyright 2017, Google, Inc. 
# Licensed under the Apache License, Version 2.0 (the "License"); 
# you may not use this file except in compliance with the License. 
# You may obtain a copy of the License at 
# 
# http://www.apache.org/licenses/LICENSE-2.0 
# 
# Unless required by applicable law or agreed to in writing, software 
# distributed under the License is distributed on an "AS IS" BASIS, 
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 
# See the License for the specific language governing permissions and 
# limitations under the License. 

# [START startup] 
set -v 

# Talk to the metadata server to get the project id 
PROJECTID=$(curl -s "http://metadata.google.internal/computeMetadata/v1/project/project-id" -H "Metadata-Flavor: Google") 

# Install logging monitor. The monitor will automatically pick up logs sent to 
# syslog. 
# [START logging] 
curl -s "https://storage.googleapis.com/signals-agents/logging/google-fluentd-install.sh" | bash 
service google-fluentd restart & 
# [END logging] 

# Install dependencies from apt 
apt-get update 
apt-get install -yq ca-certificates git nodejs build-essential supervisor 

# Install nodejs 
mkdir /opt/nodejs 
curl https://nodejs.org/dist/v4.2.2/node-v4.2.2-linux-x64.tar.gz | tar xvzf - -C /opt/nodejs --strip-components=1 
ln -s /opt/nodejs/bin/node /usr/bin/node 
ln -s /opt/nodejs/bin/npm /usr/bin/npm 

# Get the application source code from the Google Cloud Repository. 
# git requires $HOME and it's not set during the startup script. 
export HOME=/root 
git config --global credential.helper gcloud.sh 
git clone https://source.developers.google.com/p/d3-barchart/r/repo /opt/app 

# Install app dependencies 
cd /opt/app/7-gce 
npm install 

# Create a nodeapp user. The application will run as this user. 
useradd -m -d /home/nodeapp nodeapp 
chown -R nodeapp:nodeapp /opt/app 

# Configure supervisor to run the node app. 
cat >/etc/supervisor/conf.d/node-app.conf << EOF 
[program:nodeapp] 
directory=/opt/app/7-gce 
command=npm start 
autostart=true 
autorestart=true 
user=nodeapp 
environment=HOME="/home/nodeapp",USER="nodeapp",NODE_ENV="production" 
stdout_logfile=syslog 
stderr_logfile=syslog 
EOF 

supervisorctl reread 
supervisorctl update 

# Application should now be running under supervisor 
# [END startup] 

即使我的VM實例現在正確地克隆git回購,它現在收到ECONNRESET錯誤:

Jul 24 21:52:59 my-app-instance startup-script: INFO startup-script: # Get the application source code from the Google Cloud Repository. 
Jul 24 21:52:59 my-app-instance startup-script: INFO startup-script: # git requires $HOME and it's not set during the startup script. 
Jul 24 21:52:59 my-app-instance startup-script: INFO startup-script: export HOME=/root 
Jul 24 21:52:59 my-app-instance startup-script: INFO startup-script: git config --global credential.helper gcloud.sh 
Jul 24 21:52:59 my-app-instance startup-script: INFO startup-script: git clone https://source.developers.google.com/p/d3-barchart/r/repo /opt/app 
Jul 24 21:52:59 my-app-instance startup-script: INFO startup-script: Cloning into '/opt/app'... 
Jul 24 21:53:02 my-app-instance startup-script: INFO startup-script: # Install app dependencies 
Jul 24 21:53:02 my-app-instance startup-script: INFO startup-script: cd /opt/app/7-gce 
Jul 24 21:53:02 my-app-instance startup-script: INFO startup-script: npm install 
Jul 24 21:53:04 my-app-instance startup-script: INFO startup-script: npm WARN deprecated [email protected]: Jade has been renamed to pug, please install the latest version of pug instead of jade 
Jul 24 21:53:05 my-app-instance startup-script: INFO startup-script: npm WARN engine @google-cloud/[email protected]: wanted: {"node":">=6"} (current: {"node":"4.2.2","npm":"2.14.7"}) 
Jul 24 21:53:21 my-app-instance startup-script: INFO startup-script: npm WARN deprecated [email protected]: Deprecated, use jstransformer 
Jul 24 21:53:50 my-app-instance startup-script: INFO startup-script: npm WARN optional dep failed, continuing [email protected] 
Jul 24 21:54:06 my-app-instance startup-script: INFO startup-script: npm WARN deprecated [email protected]: Use uuid module instead 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! Linux 3.16.0-4-amd64 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! argv "/opt/nodejs/bin/node" "/usr/bin/npm" "install" 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! node v4.2.2 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! npm v2.14.7 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! code ECONNRESET 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! errno ECONNRESET 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! syscall read 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! network read ECONNRESET 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! network This is most likely not a problem with npm itself 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! network and is related to network connectivity. 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! network In most cases you are behind a proxy or have bad network settings. 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! network 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! network If you are behind a proxy, please make sure that the 
Jul 24 21:54:20 my-app-instance startup-script: INFO startup-script: npm ERR! network 'proxy' config is set properly. See: 'npm help config' 

說實話,我不知道這是否有助於我爲什麼不能查看外部IP我的應用程序的原因,但在目前,這是我唯一能發現錯誤。我如何解決這個問題?

回答

0

有一兩件事要檢查出是哪些端口是你防火牆規則開放。針對HTTP的默認端口爲80,HTTPS爲443

轉至防火牆規則,看看你允許訪問您的外部IP地址的端口。爲了獲得在漢堡有第一次點擊您的GCP控制檯的左上角,則:

網絡 - >防火牆規則

現在,看看你有開放的HTTP訪問端口。您可以調整服務器以偵聽端口80或添加防火牆規則以偵聽tcp:80。確保您的虛擬機已添加到創建新規則的網絡中(因此請確保將該規則添加到默認網絡)。

我會說實話,開發-OPS教程,不要做大量的手把手的,而且往往留下了很多的步驟。

+0

哎@EJ梅森,我創建了'TCP單獨的防火牆規則:80''TCP:8080''TCP:443''TCP:22',並確保我的虛擬機實例擁有的所有4個網絡標籤,但仍無法訪問我的應用程序 – doctopus

相關問題