Sto tentando di installare edx Devstack installato con Vagrant e sono su una macchina Windows. Ricevo errori che sembrano derivare da collegamenti simbolici non supportati da Windows.Vagrant - errore di devstack finitrice: "[Errno 20] Non una directory"
In base alla guida per la risoluzione dei problemi di edx sotto Dealing with line endings and symlinks under Windows, dovrei eseguire i seguenti comandi in cygwin per gestire i collegamenti simbolici.
git rm --cached -r . && git reset --hard
git config --global alias.add-symlink '!__git_add_symlink(){
dst=$(echo "$2")/../$(echo "$1");
if [ -e "$dst" ]; then
hash=$(echo "$1" | git hash-object -w --stdin);
git update-index --add --cacheinfo 120000 "$hash" "$2";
git checkout -- "$2";
else
echo "ERROR: Target $dst does not exist!";
echo " Not creating invalid symlink.";
fi;
}; __git_add_symlink "$1" "$2"'
git config --global alias.rm-symlink '!__git_rm_symlink(){
git checkout -- "$1"; link=$(echo "$1");
POS=$'\''/'\''; DOS=$'\''\\\\'\'';
doslink=${link//$POS/$DOS};
dest=$(dirname "$link")/$(cat "$link");
dosdest=${dest//$POS/$DOS};
if [ -f "$dest" ]; then
rm -f "$link";
cmd //C mklink //H "$doslink" "$dosdest";
elif [ -d "$dest" ]; then
rm -f "$link";
cmd //C mklink //J "$doslink" "$dosdest";
else
echo "ERROR: Something went wrong when processing $1 . . .";
echo " $dest may not actually exist as a valid target.";
fi;
}; __git_rm_symlink "$1"'
git config --global alias.rm-symlinks '!__git_rm_symlinks(){
for symlink in `git ls-files -s | grep -E "^120000" | cut -f2`;
do
git rm-symlink "$symlink";
git update-index --assume-unchanged "$symlink";
done;
}; __git_rm_symlinks'
git config --global alias.checkout-symlinks '!__git_checkout_symlinks(){
POS=$'\''/'\''; DOS=$'\''\\\\'\'';
for symlink in `git ls-files -s | grep -E "^120000" | cut -f2`;
do
git update-index --no-assume-unchanged "$symlink";
if [ -d "$symlink" ]; then
dossymlink=${symlink//$POS/$DOS};
cmd //C rmdir //S //Q "$dossymlink";
fi;
git checkout -- "$symlink";
echo "Restored git symlink $symlink <<===>> `cat $symlink`";
done;
}; __git_checkout_symlinks'
git rm-symlinks
ho anche provato i comandi nel SO rispondere Git symlinks in Windows, che produce gli stessi risultati.
uscita:
L'uscita ricevo dopo aver eseguito i comandi di cui sopra è un po 'strano, quindi non sono sicuro se lo script è successo.
[email protected] /cygdrive/c/.../Local/devstack/edx-platform/edx-platform $./symlinks-fix.sh
**Git checkout output**
...
Checking out files: 100% (6983/6983), done.
HEAD is now at 222bdd9 Merge pull request #10411 from edx/mobile/course-blocks-api
Microsoft Windows [Version 6.2.9200]
(c) 2012 Microsoft Corporation. All rights reserved.
C:\Users\...\Local\devstack\edx-platform\edx-platform>
Perché nel prompt dei comandi in stile Windows alla fine? È qui che non sono sicuro se i comandi git funzionino.
In Vagrant:
Dopo aver eseguito vagrant up
e vagrant ssh
, ottengo i seguenti errori durante l'esecuzione paver devstack lms
(output simile per paver devstack studio
):
[email protected]:~$ sudo su edxapp
[email protected]:~/edx-platform$ paver devstack lms
...
pip install -q --disable-pip-version-check --exists-action w -r requirements/edx/github.txt
Could not find a tag or branch '96e1922348bfe6d99201b9512a9ed946c87b7e0b', assuming commit.
.... 20 similar ....
Could not find a tag or branch 'e7a6c95c300e95c51e42bfd1eba70489c05a6527', assuming commit.
pip install -q --disable-pip-version-check --exists-action w -r requirements/edx/local.txt
pip install -q --disable-pip-version-check --exists-action w -r requirements/edx/base.txt
Requested meliae==0.4.0 (from -r requirements/edx/base.txt (line 47)), but installing version 0.4.0.final.0
pip install -q --disable-pip-version-check --exists-action w -r requirements/edx/post.txt
python manage.py cms --settings=devstack reindex_course --setup
2015-11-06 01:37:40,353 WARNING 4797 [xblock.plugin] plugin.py:147 - Unable to load XBlock 'html'
Traceback...
IOError: [Errno 20] Not a directory: '/edx/app/edxapp/edx-platform/common/lib/xmodule/xmodule/js/common_static/js/vendor/draggabilly.pkgd.js'
2015-11-06 01:37:40,660 WARNING 4797 [xblock.plugin] plugin.py:147 - Unable to load XBlock 'course_info'
Traceback...
IOError: [Errno 20] Not a directory: '/edx/app/edxapp/edx-platform/common/lib/xmodule/xmodule/js/common_static/js/vendor/draggabilly.pkgd.js'
Traceback...
IOError: [Errno 20] Not a directory: '/edx/app/edxapp/edx-platform/common/lib/xmodule/xmodule/js/common_static/js/vendor/draggabilly.pkgd.js'
Traceback ...
IOError: [Errno 20] Not a directory: '/edx/app/edxapp/edx-platform/common/lib/xmodule/xmodule/js/common_static/js/vendor/draggabilly.pkgd.js'
Traceback ...
IOError: [Errno 20] Not a directory: '/edx/app/edxapp/edx-platform/common/lib/xmodule/xmodule/js/common_static/js/vendor/draggabilly.pkgd.js'
Build failed running pavelib.servers.devstack: Subprocess return code: 1
Da quello che ho capito, questo è un problema con collegamenti simbolici (vedi il messaggio this sui gruppi di Google).
Sto eseguendo correttamente lo script dei collegamenti simbolici sopra? Come posso verificare se i collegamenti simbolici sono stati gestiti correttamente?
Altri tentativi:
seguendo i suggerimenti del gruppo Google (link qui sotto), mi hanno anche fatto le seguenti regolazioni:
- l'impostazione del VAGRANT_USE_VBOXFS = true
- utilizzando il Vagrantfile fornito here
- impostazione della variabile di ambiente OPENEDX_RELEASE = "named-release/cypress"
- installazione di libxmlsec1 dall'istanza di Vagrant.
Dopo molteplici vagrant destroy
e vagrant provision
's, ho ancora lo stesso problema IOError: [Error 20] Not a directory
. Qualsiasi aiuto sarebbe molto apprezzato!
Versioni:
- versione di Windows: 8
- versione Vagrant: 1.7.4
- versione di VirtualBox: 5.0.8
- openEdx rilascio: rilascio di nome/cipresso
Stai cercando di creare/uso collegamenti simbolici in Windows, o stai cercando di creare/uso collegamenti simbolici in VirtualBox (assumendo una macchina virtuale Linux)? – jperezov
@ Jonathan Sto provando a usare i collegamenti simbolici in file che sono memorizzati sulla mia macchina Windows e condivisi tramite VirtualBox su una VM Linux ... Almeno penso che sia così che funziona. – Evelyn
C'è un bug nel primo script dove 'hash = $ (echo" $ 1 "| git hash-object -w --stdin); 'dovrebbe essere' hash = $ (echo -n "$ 1" | git hash-object -w --stdin); '(notare l'ulteriore" -n ") – venimus