yumが間違ったNode.jsバージョンをインストールしようとしているのはなぜですか?

yumが間違ったNode.jsバージョンをインストールしようとしているのはなぜですか?

5.xCentOS 7サーバーにバージョンをインストールしようとしていますが、何らかのNode.js理由でバージョンをインストールしようとし、yumダウンロードサイトでバージョンが見つからない場合は0.xエラーが返されます。このエラーは、バージョンファイル名がバージョンURLに関連付けられていることを示します。私はこれがCentOS 7システムの設定に問題があることを示していると思います。0.x5.xyum0.x5.xyumバージョン5.xをインストールするには、次のうちどれを具体的に変更する必要がありますか?

ルートエラーメッセージは次のとおりです。

Error downloading packages:
  nodejs-0.10.42-1nodesource.el7.centos.x86_64: [Errno 256] No more mirrors to try.

以下のコードのソースはサイト運営者ページで確認できます。次のリンクから。さらに、次のことがいくつかの合併症を引き起こす可能性があります。この他のリンクの指示に従って最初の試み。以前の試みの残りの部分を調べるために、現在次のコマンドを実行して結果を待っています。grep -rnw '/path/to/somewhere/' -e "pattern"

ノードソース位置を設定するための端末出力は次のとおりです。

[root@localhost tmp]# curl --silent --location https://rpm.nodesource.com/setup_5.x | bash -
## Installing the NodeSource Node.js 5.x repo...
## Inspecting system...
+ rpm -q --whatprovides redhat-release || rpm -q --whatprovides centos-release || rpm -q --whatprovides cloudlinux-release || rpm -q --whatprovides sl-release
+ uname -m
## Confirming "el7-x86_64" is supported...
+ curl -sLf -o /dev/null 'https://rpm.nodesource.com/pub_5.x/el/7/x86_64/nodesource-release-el7-1.noarch.rpm'
## Downloading release setup RPM...
+ mktemp
+ curl -sL -o '/tmp/tmp.sH82u4Gpap' 'https://rpm.nodesource.com/pub_5.x/el/7/x86_64/nodesource-release-el7-1.noarch.rpm'
## Installing release setup RPM...
+ rpm -i --nosignature --force '/tmp/tmp.sH82u4Gpap'
## Cleaning up...
+ rm -f '/tmp/tmp.sH82u4Gpap'
## Checking for existing installations...
+ rpm -qa 'node|npm' | grep -v nodesource
## Run `yum install -y nodejs` (as root) to install Node.js 5.x and npm.
## You may also need development tools to build native addons:
##   `yum install -y gcc-c++ make`

/tmp以下は、上記のコマンドを実行した後のフォルダの内容の一覧です。

[root@localhost tmp]# ls -al
total 8
drwxrwxrwt. 13 root   root    320 Feb 14 06:13 .
dr-xr-xr-x. 19 root   root   4096 Jan 29 20:54 ..
drwx------.  2 user   user     60 Feb 13 20:05 .esd-1000
drwxrwxrwt.  2 root   root     40 Feb 13 20:04 .font-unix
prw-------.  1 root   root      0 Feb 13 20:05 hogsuspend
drwxrwxrwt.  2 root   root     80 Feb 13 20:05 .ICE-unix
srwxrwxrwx.  1 mongod mongod    0 Feb 13 20:04 mongodb-27017.sock
drwx------.  2 user   user     40 Dec 31  1969 orbit-user
drwx------.  2 user   user     60 Feb 13 20:05 ssh-AmQyH8IIEC2m
drwx------.  3 root   root     60 Feb 13 20:05 systemd-private-74534ca9946043cc88dbe52a38b4344d-colord.service-hDR3Cd
drwx------.  3 root   root     60 Feb 13 20:04 systemd-private-74534ca9946043cc88dbe52a38b4344d-rtkit-daemon.service-ZAQmPk
drwxrwxrwt.  2 root   root     40 Feb 13 20:04 .Test-unix
drwx------.  2 user   user     40 Feb 13 20:08 tracker-extract-files.1000
-r--r--r--.  1 root   root     11 Feb 13 20:05 .X0-lock
drwxrwxrwt.  2 root   root     60 Feb 13 20:05 .X11-unix
drwxrwxrwt.  2 root   root     40 Feb 13 20:04 .XIM-unix

nodejsインストールを使用しようとした結果は次のとおりですyum

[root@localhost tmp]# yum install -y nodejs
Loaded plugins: fastestmirror, langpacks
Loading mirror speeds from cached hostfile
 * base: mirror.lax.hugeserver.com
 * epel: mirror.sfo12.us.leaseweb.net
 * extras: mirror.keystealth.org
 * updates: mirror.supremebytes.com
Resolving Dependencies
--> Running transaction check
---> Package nodejs.x86_64 0:0.10.42-1nodesource.el7.centos will be installed
--> Finished Dependency Resolution
Dependencies Resolved
================================================================================================================================================================================
 Package                            Arch                               Version                                                     Repository                              Size
================================================================================================================================================================================
Installing:
 nodejs                             x86_64                             0.10.42-1nodesource.el7.centos                              nodesource                             4.5 M

Transaction Summary
================================================================================================================================================================================
Install  1 Package

Total download size: 4.5 M
Installed size: 16 M
Downloading packages:
No Presto metadata available for nodesource
nodejs-0.10.42-1nodesource.el7 FAILED                                          
https://rpm.nodesource.com/pub_5.x/el/7/x86_64/nodejs-0.10.42-1nodesource.el7.centos.x86_64.rpm: [Errno 14] HTTPS Error 404 - Not Found       ]  0.0 B/s |    0 B  --:--:-- ETA 
Trying other mirror.
To address this issue please refer to the below knowledge base article 

https://access.redhat.com/articles/1320623

If above article doesn't help to resolve this issue please create a bug on https://bugs.centos.org/

Error downloading packages:
  nodejs-0.10.42-1nodesource.el7.centos.x86_64: [Errno 256] No more mirrors to try.
[root@localhost tmp]# 

記録のために、gedit /etc/yum.repos.d/nodesource-el.repo以下が表示されます。

[nodesource]
name=Node.js Packages for Enterprise Linux 7 - $basearch
baseurl=https://rpm.nodesource.com/pub_5.x/el/7/$basearch
failovermethod=priority
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/NODESOURCE-GPG-SIGNING-KEY-EL

[nodesource-source]
name=Node.js for Enterprise Linux 7 - $basearch - Source
baseurl=https://rpm.nodesource.com/pub_5.x/el/7/SRPMS
failovermethod=priority
enabled=0
gpgkey=file:///etc/pki/rpm-gpg/NODESOURCE-GPG-SIGNING-KEY-EL
gpgcheck=1  

以前に別のコマンドを実行して問題が発生したと思われます。

curl --silent --location rpm.nodesource.com/setup | bash -

根本的な問題は、yumがこれらの結果を維持する方法だと思います。curl --silent --location ... | bash - commands


制御ケース:


別の仮想マシンにCentOS 7を新規インストールする場合、次の3つの簡単なコマンドを使用すると、Nodejsの正しい現在のバージョン5.xが正常にインストールされました。

# cd /tmp
# curl --silent --location https://rpm.nodesource.com/setup_5.x | bash -
# yum install -y nodejs  
# node --version
v5.6.0  

コントロールケースのこれらの結果は、問題のあるコンピュータでyumを設定する方法に問題があることを示しています。 それでは、正しいダウンロードURLを生成するようにyumを設定するには、そのコンピュータにどのような具体的な変更を適用する必要がありますか? すべてを別の仮想マシンに移植することは不合理です。もちろん、これはこの問題を解決するために変更できるyum設定の1〜2行にすぎません。

ベストアンサー1

これはキャッシュの問題のようですが、何が間違っているのかは明らかではありません。チャットでポスターといくつかの会話を交わした後に実行してyum clean all問題を解決しました。

ポスターは以下を指摘します。

[root@localhost yum]# ls /var/cache/yum/x86_64/7/nodesource/packages 
nodejs-0.10.42-1nodesource.el7.centos.x86_64.rpm 
[root@localhost yum]# yum clean all
[root@localhost yum]# ls /var/cache/yum/x86_64/7/nodesource/packages 
[root@localhost yum]# yum install -y nodejs
.... much terminal output during successful install
[root@localhost yum]# node --version
v5.6.0

したがって、yum clean allキャッシュにすでに保存されている古いパッケージは削除されます。

Red Hat ベースのディストリビューションの知識や経験がないため、ここで何が間違っているのかはわかりません。

おすすめ記事