bash - 在 IBM i 上将 Composer 与私有(private) VCS 存储库一起使用时出现 Git 依赖性错误

标签 bash git composer-php ibm-midrange

下面有更多详细信息,但是当我在使用自定义 VCS 存储库的项目上发出 composer installcomposer update 命令时遇到以下错误一个包含的项目。这是通过 SSH session 在 IBM i v7r3 系统上进行的。我已经没有关于如何进一步排除故障的想法,所以我来了。有没有人见过此错误或对如何进一步排除故障有任何想法?

错误:

bash-4.4$ composer install
Loading composer repositories with package information
Installing dependencies (including require-dev) from lock file
Package operations: 113 installs, 0 updates, 0 removals
  - Installing sshUser/myPackage (v1.0.26): Cloning a2db0666b1


  [RuntimeException]
  Failed to clone gitUser:/opt/git/myPackage.git, git was not found, check that
   it is installed and in your PATH env.

  Could not load program git:
        Dependent module /usr/local/zendphp7/lib/libz.so.1(shr_64.o) could not be loaded.

        File /usr/local/zendphp7/lib/libz.so.1 is not an

          archive or the file could not be read properly.

  System error: Exec format error

我有一个远程 IBM i 服务器,它有两个用户。第一个用户“gitUser”用于我的私有(private) Git 存储库( headless )。然后我有另一个用户“sshUser”,用于 SSH 并执行我的典型工作。我配置了 SSH key 来简化两个用户的连接,“gitUser”ssh key 不需要密码,所以我可以用它来自动编写脚本。

我的项目的 composer.json 文件中包含一个私有(private) VCS 存储库。只要我在“存储库”部分中有条目,我就会收到上述错误。即使我不需要存储库中的包,也会发生这种情况。

存储库条目:

"repositories": [
    {
        "type": "vcs",
        "url":  "gitUser:/opt/git/myPackage.git"
    }
]

IBM i 上的 Composer 最新版本为 1.7.2。

很明显,问题在于 git 以及无法在 libz.so.1 中找到依赖项。

但是,如果我在我的路径中遵循 Git 版本的依赖链,则所有适当的文件都具有足够的权限:

bash-4.4$ which git                                                   
/QOpenSys/pkgs/bin/git                                                
bash-4.4$ dump -X64 -H /QOpenSys/pkgs/bin/git                         

/QOpenSys/pkgs/bin/git:                                               

                        ***Loader Section***                          
                      Loader Header Information                       
VERSION#         #SYMtableENT     #RELOCent        LENidSTR           
0x00000001       0x000000df       0x0000433f       0x0000009d         

#IMPfilID        OFFidSTR         LENstrTBL        OFFstrTBL          
0x00000006       0x00044910       0x00000a18       0x000449ad         


                        ***Import File Strings***                     
INDEX  PATH                          BASE                MEMBER       
0      /QOpenSys/pkgs/lib:/QOpenSys/usr/lib                           
1                                    libz.so.1           shr_64.o     
2                                    libiconv.so.2       shr_64.o     
3                                    libcrypto.so.1.0.0  shr_64.o     
4                                    libpthread.a        shr_xpg5_64.o
5                                    libc.a              shr_64.o     
bash-4.4$                                                             

我可以确认在所有这些过程中没有权限失败。所以这似乎不是权限不足的结果。另外,我不认为问题出在用户配置文件 gitUser 中,就好像我从另一台机器发出 composer installcomposer update (用适当的键),一切都完美无缺。所以它似乎特定于 IBM i 和 sshUser 配置文件。

我开始认为 Composer 正在使用不同的 git 可执行文件,并且该可执行文件的依赖项不存在。尽管我认为 Composer 只会使用我的路径。

注意*:我尝试使用以下内容在我的 ./.profile 中指定我的 LIBPATH。但这似乎没有任何区别:

LIBPATH=/usr/local/zendphp7/lib
LIBPATH=$LIBPATH:/QOpenSys/pkgs/lib:/QOpenSys/usr/lib
export LIBPATH

回显时:

bash-4.4$ echo $LIBPATH
/usr/local/zendphp7/lib:/QOpenSys/pkgs/lib:/QOpenSys/usr/lib
bash-4.4$

如果我没有将以上内容添加到我的 ./.profile,则 echo $LIBPATH 会在屏幕上打印一个空行。

解决方案: 我只是将 ZENDPHP7 目录结构中的符号链接(symbolic link)更改为 repo 版本。或者,您可以操纵您的库路径,但我无法找出在 IBM i 上执行此操作的正确方法。

bash-4.4$ pwd
/usr/local/zendphp7/lib
bash-4.4$ ln -s /QOpenSys/pkgs/lib/libz.so.1 ./libz.so.1
bash-4.4$ ls -la /usr/local/zendphp7/lib/libz.so.1
lrwxrwxrwx 1 dl 0 56 Oct 11 14:21 /usr/local/zendphp7/lib/libz.so.1 -> /QOpenSys/pkgs/lib/libz.so.1
bash-4.4$

最佳答案

我猜您在安装时遇到了问题。它可能会查看 Zend PHP 库而不是/usr/lib 中预期的库吗?

请注意,错误显示路径为 /usr/local/zendphp7/lib/ libz.so.1(shr_64.o) 而您的 git 转储显示为 /QOpenSys/pkgs/lib:/QOpenSys/usr/lib.

关于bash - 在 IBM i 上将 Composer 与私有(private) VCS 存储库一起使用时出现 Git 依赖性错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52748548/

相关文章:

bash - 通过 bash curl 发送邮件

Gitlab CI如何将最新部署到特定目录

python - 我将如何使用 php 在网页上显示多个按钮(它们将控制 raspberry pi)

docker - 在 Dockerfile 中运行 composer install

bash - 在 mac OS X 中登录时运行脚本

bash - 使用 bc 在 bash 中进行 float 学运算

Git fatal error : unable to stat '*' : No such file or directory

git subtree 将更改推回子树项目

php - 在构建 Docker 时,如何将 Composer 缓存存储在卷中?

bash - 为什么 `ls | cat` != `ls` ?