1
votes

comment analyser la chaîne en variables

Je veux pouvoir lire chaque ligne d'un fichier qui contient des lignes qui ressemblent à: redhat-ubi-ubi7-7.8 vendor = redhat, product = ubi, image_name = ubi7 , tag = 7.8 afin que je puisse les faire analyser afin de faire quelque chose comme:

  while read -r line; 
  do
    vendor=sed/awk
    product=sed/awk
    image_name=sed/awk
    version=sed/awk
    echo "Copying $image_name:$version into registry..."

    skopeo copy \
    docker-archive:/opt/app-root/src/ironbank-images/"$line" \
    docker://"$REGISTRY_DOMAIN"/"$vendor"/"$product"/"$image_name":"$version" \
    --dest-creds="$REGISTRY_USERNAME":"$REGISTRY_PASSWORD" \
    --dest-tls-verify=false

  done < "$SYNC_IMAGES"

Comment puis-je séparer cette chaîne afin d'obtenir le résultat souhaité pour mon cas d'utilisation ?


2 commentaires

Pourquoi faites-vous cela avec une boucle shell plutôt que de tout faire dans awk ?


Qu'en est-il de votre dernière question ?


3 Réponses :


0
votes

Utilisez simplement awk avec - comme séparateur de champ.

awk -F- -v domain="$REGISTRY_DOMAIN" -v user="$REGISTRY_USER" -v pw="$REGISTRY_PASSWORD" '
    {   vendor = $1; product = $2; image_name = $3; version = $4;
        printf("echo \"Copying %s:%s into registry\"\n", image_name, version);
        printf("skopeo copy docker-archive:/opt/app-root/src/ironbank-images/\"%s\" docker://\"%s\"/\"%s\"/\"%s\"/\"%s\":\"$version\" --dest-creds=\"%s\":\"%s\" --dest-tls-verify=false\n",
            domain, vendor, product, image_name, version, user, pw)
    }' < "$SYNC_IMAGES" | bash


0 commentaires

3
votes

Une combinaison de la fonction multi-variables de read et de IFS ferait l'affaire:

while IFS=- read -r vendor product image_name version; 
do
    echo "Copying $image_name:$version into registry..."

    skopeo copy \
        docker-archive:/opt/app-root/src/ironbank-images/"${vendor}-${product}-${image_name}-${version}" \
        docker://"$REGISTRY_DOMAIN"/"$vendor"/"$product"/"$image_name":"$version" \
        --dest-creds="$REGISTRY_USERNAME":"$REGISTRY_PASSWORD" \
        --dest-tls-verify=false

done < "$SYNC_IMAGES"


1 commentaires

Ce deuxième echo est bon pour le débogage, mais empêcherait le code de s'exécuter.



0
votes

Juste au cas où vous voudriez utiliser P.E. expansion des paramètres.

while read -r string; do
  vendor=${string%%-*} version=${string##*-} image_name=${string%-*}
  product=${image_name#*-} product=${product%-*} image_name=${image_name##*-}

  echo "Copying $image_name:$version into registry..."

  echo skopeo copy \
        docker-archive:/opt/app-root/src/ironbank-images/"${vendor}-${product}-${image_name}-${version}" \
        docker://"${REGISTRY_DOMAIN}"/"$vendor"/"$product"/"$image_name":"$version" \
        --dest-creds="${REGISTRY_USERNAME}":"${REGISTRY_PASSWORD}" \
        --dest-tls-verify=false
done < "$SYNC_IMAGES"


0 commentaires