Aquí abajo encontrarás las instrucciones para configurar tu computadora para el curso de Data Science de Le Wagon
Por favor léelas cuidadosamente y ejecuta todos los comandos en el siguiente orden. Si tienes algún problema, no dudes en pedirle ayuda a una profesor 🙋
¡Comencemos! 🚀
¿Ya tienes una cuenta GitHub? Si no es el caso, ábrela ya.
👉 Sube una foto y escribe tu nombre correctamente en tu cuenta GitHub. Esto es importante porque nosotros usaremos un tablero de comando interno con tu avatar. Por favor hazlo ahora antes de dar un paso más en esta guía.
GCP es una solución en la nube que usarás para colocar tus productos basados en Machine Learning en producción.
🚨 Si estás en el grupo de estudiantes del Bootcamp de Medio Tiempo, ¡IGNORA ESTA SECCIÓN POR AHORA! GCP ofrece $300 en créditos durante 3 meses, así que no es buena idea activar tu cuenta GCP demasiado pronto 🙅♂️
- Ve a Google Cloud y crea una cuenta si aún no tienes una
- En la consola de Cloud, en la lista de proyectos, selecciona o crea un proyecto Cloud
- Asígnale un nombre como
Wagon Bootcamp
por ejemplo - Verás que se creará un
ID
automáticamente para el proyecto e. g.wagon-bootcamp-123456
Abre las preferencias en tu cuenta GCP para facilitar el seguimiento de las instrucciones durante el bootcamp:
https://myaccount.google.com/language
Si el idioma de preferencia no es:
- English
- United States
Cámbialo a inglés:
- Haz clic en el logo edición (es una lapicera)
- Selecciona English
- Selecciona United States
- Haz clic en Select
Ahora conecta tu cuenta con tu tarjeta de crédito. Este paso es obligatorio para poder usar los servicios que suministra GCP. No te preocupes, podrás utilizar la mayoría de los servicios de GCP por medio de créditos gratuitos durante el bootcamp.
- Haz clic en Billing
- Haz clic en MANAGE BILLING ACCOUNTS
- Haz clic en ADD BILLING ACCOUNT
- Asígnale un nombre a tu cuenta de facturación, e. g.
My Billing Account
- Haz clic en "I have read..." y acepta los términos de uso
- Haz clic en CONTINUE
- Selecciona tu tipo de cuenta:
Individual
- Agrega tu nombre y dirección
Verás que tienes créditos gratuitos con un valor de "$300 a utilizar en los próximos 90 días".
- Haz clic en los detalles de la tarjeta
- Agrega la información de tu tarjeta de crédito
- Haz clic en START MY FREE TRIAL. Esto significa comenzar mi período de prueba.
Cuando termines, verifica que la cuenta de facturación esté conectada con tu proyecto GCP.
- Selecciona tu proyecto
- Ve a Billing
- Selecciona LINK A BILLING ACCOUNT
- Selecciona
My Billing Account
- Haz clic en SET ACCOUNT
Ahora deberías ver lo siguiente:
Free trial status: $300 credit and 91 days remaining - with a full account, you'll get unlimited access to all of Google Cloud Platform.
Esto significa Estado de período de prueba: crédito de $300 y 91 días para usarlo - con la full account, tendrás acceso ilimitado a todo lo que ofrece Google Cloud Platform.
👉 Si no tienes una tarjeta de crédito 👈
Si no tienes una tarjeta de crédito, puedes abrir una cuenta en Revolut. Revolut es una aplicación que funciona como un banco y que te permitirá crear una tarjeta de crédito virtual conectada a la dirección de facturación de tu smartphone.
Ignora este paso si ya tienes una tarjeta de crédito. Simplemente úsala para hacer la configuración.
Descarga la app Revolut o ve a revolut y sigue los pasos para descargar la app (introduce tu número de teléfono móvil y haz clic en Get Started).
- Abre la app Revolut
- Agrega tu número de teléfono móvil
- Agrega el código de verificación que recibiste por SMS
- La app te preguntará por tu país, dirección, primer y segundo nombre, fecha de nacimiento y el email
- La app también te pedirá tu profesión y una selfie
- La app te pedirá una foto de tu documento nacional de identidad o pasaporte
Cuando termines, selecciona el plan estándar (gratuito). No tienes que agregar la tarjeta a Apple pay, pedir que te envíen una tarjeta a tu domicilio ni tampoco agregar dinero a la cuenta.
Ahora tienes una tarjeta virtual que podrás usar para hacer la configuración de GCP.
En la vista principal de la app Revolut
- Haz clic en Ready to use
- Haz clic en the card
- Haz clic en Show card details
- Toma nota de la información de la tarjeta de crédito virtual y úsala para completar la configuración de GCP
👉 Si recibes un email de Google diciendo "Urgent: your billing account XXXXXX-XXXXXX-XXXXXX has been suspended" 👈
Esto puede pasar justo después de haber creado la cuenta en Revolut.
- Haz clic en PROCEED TO VERIFICATION
- Te pedirán que envíes una foto de tu tarjeta de crédito (solo los últimos 4 dígitos, nada más)
- Si ya has usado Revolut, puedes enviar una captura de pantalla de tu tarjeta de crédito virtual (no olvides quitar la fecha de vencimiento de la captura)
- Explica que estás haciendo el bootcamp de Le Wagon, que no tienes una tarjeta de crédito y que acabas de crear una cuenta en Revolut para poder configurar GCP para el bootcamp con una tarjeta de crédito virtual
Es posible que te validen la cuenta pero también es posible que te pidan más información en los próximos 30 minutos.
Cuando la cuenta sea validada recibirás un email diciendo lo siguiente: "Your Google Cloud Platform billing account XXXXXX-XXXXXX-XXXXXX has been fully reinstated and is ready to use.". Esto significa que tu cuenta Google Cloud Platform ha sido restablecida
- Asegúrate de que la facturación está habilitada para tu proyecto Google Cloud
ℹ️ Tienes un crédito de $300 para usar con recursos de Google Cloud. Esto será más que suficiente para el bootcamp.
- Habilita las APIs AI Platform Training & Prediction y Compute Engine APIs (Esto puede tomar varios minutos)
- Autentica el CLI de
gcloud
con la cuenta que usaste para GCP
gcloud auth login
- Inicia sesión en tu cuenta Google en la nueva pestaña que se abrió en tu navegador
- Lista la cuenta que tienes activa y verifica que el email que usaste para GCP está ahí
gcloud auth list
- Define tu proyecto actual (reemplaza
PROJECT_ID
con elID
de tu proyecto e.g.wagon-bootcamp-123456
)
gcloud config set project PROJECT_ID
- Lista la cuenta que tienes activa y tu proyecto actual y verifica que tu proyecto está ahí
gcloud config list
Como ya creaste una cuenta GCP account
y un project
(identificado por su PROJECT_ID
), vamos a configurar las acciones (llamadas API calls) que quieres que tu código ejecute.
🤔 ¿Por qué necesitamos una clave de cuenta de servicio?
Creaste una cuenta GCP
conectada a una tarjeta de crédito. Te facturarán de acuerdo al uso que les des a los recursos de Google Cloud Platform. El cargo se hará si utilizas algo después de que el período de prueba gratuito se haya terminado o si te excedes del límite de consumo que te permite dicho período.
En tu cuenta GCP
has creado un solo proyecto GCP
identificado por su PROJECT_ID
. Los proyectos GCP
te permiten organizar y monitorear la manera en que consumes los recursos GCP de forma más precisa. En este bootcamp solo crearemos un solo proyecto.
Ahora necesitamos una manera de saber qué recursos nuestro código podrá consumir dentro de un GCP project
. Nuestro código consume recursos GCP por medio de llamadas API.
Ya que las llamadas API no son gratuitas, es importante definir cuidadosamente cómo nuestro código las utilizará. Sin embargo, durante el bootcamp no habrá restricciones. Le permitiremos a nuestro código que utilice todas las API GCP sin restricciones.
Así como pueden haber varios proyectos asociados a una cuenta GCP, un proyecto puede estar compuesto de muchos servicios (cualquier paquete de código, sin importar su formato, que necesite utilizar llamadas a la API de GCP para cumplir con su propósito).
GCP exige que los servicios de los proyectos que usen llamadas API se registren en la plataforma y que se configuren sus credenciales por medio del acceso concedido a una service account
.
Por ahora solo tendremos que usar un solo servicio y crearemos la service account
correspondiente.
Ya que la service account es lo que identifica tu aplicación (y por ende tu cuenta de facturación GCP y, en última instancia, tu tarjeta de crédito), lo mejor es ser cuidadoso en los próximos pasos.
- Ve a la página de las cuentas de servicio
- Selecciona tu proyecto en la lista de proyectos recientes si te piden que
- Crees una cuenta de servicio:
- Haz clic en CREATE SERVICE ACCOUNT que significa crear une cuenta de servicio:
- Define un
Service account name
para esa cuenta. Esto significa Nombre de cuenta de servicio - Haz clic en CREATE AND CONTINUE que significa crear y continuar
- Haz clic en Select a role que significa selecciona un rol. Escoge
Quick access/Basic
luego Owner. Esto otorga acceso total a todos los recursos - Haz clic en CONTINUE
- Haz clic en DONE
- Descarga la 🔑 del archivo json de la cuenta de servicio:
- Haz clic en la cuenta de servicio recién creada
- Haz clic en KEYS
- Haz clic en ADD KEY y luego en Create new key
- Selecciona JSON y haz clic en CREATE
El navegador acaba de guardar la 🔑 del archivo json de la cuenta de servicio en tu carpeta de descargas (el nombre se le asigna según el nombre de la cuenta de servicio. Es algo como le-wagon-data-123456789abc.json
)
Instala algunas extensiones útiles para VS Code.
code --install-extension ms-vscode.sublime-keybindings
code --install-extension emmanuelbeziat.vscode-great-icons
code --install-extension MS-vsliveshare.vsliveshare
code --install-extension ms-python.python
code --install-extension KevinRose.vsc-python-indent
code --install-extension ms-python.vscode-pylance
code --install-extension ms-toolsai.jupyter
Aquí está la lista de las extensiones que estás instalando:
- Sublime Text Keymap and Settings Importer
- VSCode Great Icons
- Live Share
- Python
- Python Indent
- Pylance
- Jupyter
Instalemos el plugin zsh
Oh My Zsh.
Ejecuta este comando en la terminal:
sh -c "$(curl -fsSL https://raw.github.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
Si te preguntan "Do you want to change your default shell to zsh?", presiona Y
Cuando termines, tu terminal debería lucir así:
✔️ Si es el caso, puedes continuar 👍
❌ Si no, por favor pídele ayuda a un profesor.
CLI es una abreviación de Command-line Interface que significa interfaz de línea de comando.
En esta sección usaremos GitHub CLI para interactuar directamente con GitHub desde la terminal.
Ya debería haberse instalado en tu computadora con los comandos que ejecutaste anteriormente.
Lo primero que hay que hacer para iniciar sesión es copiar y pegar el comando siguiente en tu terminal:
email
gh auth login -s 'user:email' -w
gh le hará algunas preguntas:
What is your preferred protocol for Git operations?
Con las flechas, elige SSH
y presiona Enter
. SSH es un protocolo para iniciar la sesión utilizando claves SSH en lugar de la famosa pareja nombre de usuario y contraseña.
Generate a new SSH key to add to your GitHub account?
Presiona Enter
para pedirle a gh que genere las claves SSH por ti.
Si ya tienes claves SSH, verás en su lugar Upload your SSH public key to your GitHub account?
Con las flechas, selecciona la ruta de tu archivo de clave pública y pulsa Intro
.
Enter a passphrase for your new SSH key (Optional)
. Pon algo que quieras y que recuerdes. Es una contraseña para proteger tu private key que está almacenada en tu disco duro. Luego presiona Enter
.
Enter
al terminar.
Obtendrás el siguiente resultado:
! First copy your one-time code: 0EF9-D015
- Press Enter to open github.com in your browser...
Selecciona y copia el código (0EF9-D015
en el ejemplo) y luego presiona Enter
.
Tu navegador se abrirá y te pedirá que autorices GitHub CLI para usar tu cuenta GitHub. Acepta y espera un poco.
Regresa a la terminal, presiona Enter
nuevamente y listo. Eso es todo.
Para verificar que están conectado correctamente, escribe lo siguiente:
gh auth status
✔️ Si obtienes este mensaje: Logged in to github.com as <YOUR USERNAME>
, significa que todo está bien 👍
❌ De lo contrario, contacta a un profesor.
Instala la CLI de gcloud
para comunicar con Google Cloud Platform a través de la terminal:
echo "deb [signed-by=/usr/share/keyrings/cloud.google.gpg] https://packages.cloud.google.com/apt cloud-sdk main" | sudo tee -a /etc/apt/sources.list.d/google-cloud-sdk.list
sudo apt-get install apt-transport-https ca-certificates gnupg
curl https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key --keyring /usr/share/keyrings/cloud.google.gpg add -
sudo apt-get update && sudo apt-get install google-cloud-sdk
sudo apt-get install google-cloud-sdk-app-engine-python
👉 Documentación para la instalación
- Guarda el archivo json de la cuenta de servicio en un lugar que recuerdes. Por ejemplo:
/home/LINUX_USERNAME/code/GITHUB_NICKNAME/gcp/SERVICE_ACCOUNT_JSON_FILE_CONTAINING_YOUR_SECRET_KEY.json
- Guarda la ruta absoluta al archivo
JSON
como una variable de entorno:
echo 'export GOOGLE_APPLICATION_CREDENTIALS=/path/to/the/SERVICE_ACCOUNT_JSON_FILE_CONTAINING_YOUR_SECRET_KEY.json' >> ~/.aliases
Hay tres opciones, escoge una:
Ya hice el bootcamp de Web Development (FullStack) de Le Wagon en la misma laptop
Esto significa que ya has hecho el fork del repositorio GitHub lewagon/dotfiles
pero tal vez la configuración para el nuevo bootcamp de Data Science no estaba lista en ese momento.
Abre tu terminal y ve a tu proyecto dotfiles
:
cd ~/code/<YOUR_GITHUB_NICKNAME>/dotfiles
code . # Open it in VS Code
En VS Codeabre el archivo zshrc
. Reemplaza su contenido con la versión más reciente de ese archivo que te suministramos. Luego guárdalo en el disco.
Regresa a la terminal y ejecuta un git diff
y pídele a un TA que venga y verifique este cambio de configuración. Debería ver cosas de Python y pyenv
.
Cuando el TA termine de hacer la verificación, haz un commit y haz el push de tus cambios:
git add zshrc
git commit -m "Update zshrc for Data Science bootcamp"
git push origin master
O
No he hecho el bootcamp de Web Development (FullStack) de Le Wagon
Los hackers aman mejorar sus shells y sus herramientas. Comenzaremos con una configuración por defecto genial proporcionada por Le Wagon y almacenada en GitHub. Tu configuración es personal, así que necesitas tu propio repositorio para almacenarla. Primero tienes que hacer el fork del repositorio en tu cuenta GitHub.
➡️ Haz clic aquí para hacer el fork del repositorio lewagon/dotfiles
a tu cuenta (deberás hacer clic nuevamente en tu foto para confirmar dónde harás el fork).
Hacer un fork significa que crearás un nuevo repositorio en tu cuenta GitHub idéntico al original. Tendrás un nuevo repositorio en tu cuenta GitHub, your_github_username/dotfiles
. El fork es necesario porque cada uno de ustedes necesitará poner información específica (e.g. tu nombre) en esos archivos.
Abre tu terminal y ejecuta el comando siguiente:
export GITHUB_USERNAME=`gh api user | jq -r '.login'`
echo $GITHUB_USERNAME
Deberías ver tu usuario GitHub. Si no es así, no hagas más nada y pide ayuda.
Parece que hay un problema con el paso anterior (gh auth
).
Es hora de hacer el fork del repositorio y clonarlo en tu laptop:
mkdir -p ~/code/$GITHUB_USERNAME && cd $_
gh repo fork lewagon/dotfiles --clone
Ejecuta el instalador de dotfiles
.
cd ~/code/$GITHUB_USERNAME/dotfiles && zsh install.sh
Verifica los emails registrados en tu cuenta GitHub. Deberás seleccionar uno de ellos en el próximo paso:
gh api user/emails | jq -r '.[].email'
Ejecuta el instalador de git:
cd ~/code/$GITHUB_USERNAME/dotfiles && zsh git_setup.sh
☝️ Esto te guiará con tu nombre (FirstName LastName
) y con tu email. Cuidado, debes poner uno de los emails de la lista de arriba que te suministra el comando gh api ...
usado anteriormente. Si haces eso, Kitt no podrá hacerle seguimiento a tu progreso.
Ahora cierra todas las ventanas de tu terminal que tengas abiertas por favor.
OR
IYa hice el bootcamp de Web Development (FullStack) de Le Wagon pero tengo una nueva laptop
Abre tu terminal y ejecuta el comando siguiente:
export GITHUB_USERNAME=`gh api user | jq -r '.login'`
echo $GITHUB_USERNAME
Deberías ver tu usuario GitHub. Si no es así, no hagas más nada y pide ayuda.
Parece que hay un problema con el paso anterior (gh auth
).
Es hora de hacer el fork del repositorio y clonarlo en tu laptop:
mkdir -p ~/code/$GITHUB_USERNAME && cd $_
gh repo fork lewagon/dotfiles --clone
Ejecuta el instalador de dotfiles
.
cd ~/code/$GITHUB_USERNAME/dotfiles && zsh install.sh
Verifica los emails registrados en tu cuenta GitHub. Deberás seleccionar uno de ellos en el próximo paso:
gh api user/emails | jq -r '.[].email'
Ejecuta el instalador de git:
cd ~/code/$GITHUB_USERNAME/dotfiles && zsh git_setup.sh
☝️ Esto te guiará con tu nombre (FirstName LastName
) y con tu email. Cuidado, debes poner uno de los emails de la lista de arriba que te suministra el comando gh api ...
usado anteriormente. Si haces eso, Kitt no podrá hacerle seguimiento a tu progreso.
Ahora cierra todas las ventanas de tu terminal que tengas abiertas por favor.
No vas a querer que te pidan tu passphrase cada vez que te comuniques con un repositorio remoto. Por eso debes agregarle plugin ssh-agent
a oh my zsh
:
Primero abre el archivo .zshrc
:
code ~/.zshrc
Luego:
- Identifica la línea que comienza por
plugins=
- Agrega
ssh-agent
al final de la lista de plugins
La lista debería verse de la siguiente manera:
plugins=(gitfast last-working-dir common-aliases zsh-syntax-highlighting history-substring-search pyenv ssh-agent)
✔️ Guarda el archivo .zshrc
con Ctrl
+ S
y cierra tu editor de texto.
Docker es una plataforma abierta para desarrollo, entrega y operación de aplicaciones.
Si ya tienes Docker instalado en tu máquina, por favor actualízalo con la versión más reciente
Ve a la documentación de instalación de Docker.
Luego sigue las instrucciones del tutorial para instalar Docker usando el repositorio. Hay 2 pasos:
- SET UP THE REPOSITORY. Esto significa configurar el repositorio
- INSTALL DOCKER ENGINE. Esto significa instalar el motor de Docker
Cuando termines, podrás ejecutar lo siguiente:
sudo service docker start
sudo docker run hello-world
Debería aparecer el siguiente mensaje:
sudo service docker stop
Kubernetes (K8s) is a system designed to make deploying auto-scaling containerized applications easily.
sudo curl -fsSLo /usr/share/keyrings/kubernetes-archive-keyring.gpg https://packages.cloud.google.com/apt/doc/apt-key.gpg
echo "deb [signed-by=/usr/share/keyrings/kubernetes-archive-keyring.gpg] https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list
curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
sudo install minikube-linux-amd64 /usr/local/bin/minikube
To test you can launch a cluster run:
minikube start
you should see your cluster booting up :
Then to check the cluster run:
kubectl get po -A
you should be able to see your cluster running! :
To tear it all down for now:
minikube delete --all
Instalación de Python (con pyenv
)
Ubuntu viene con una versión vieja de Python que no queremos usar. Tal vez ya hayas instalado Anaconda u otro programa para utilizar Python y paquetes de Ciencia de Datos. Si es así, no pasa nada ya que haremos una configuración profesional de Python que te permitirá cambiar de versión cuando quieras al escribir python
en la terminal.
Primero instala pyenv
con el siguiente comando en la Terminal:
git clone https://github.com/pyenv/pyenv.git ~/.pyenv
exec zsh
Ignora el mensaje pyenv: no such command 'virtualenv-init' for now
.
Instala algunas dependencias necesarias para crear Python desde pyenv
:
sudo apt-get update; sudo apt-get install make build-essential libssl-dev zlib1g-dev \
libbz2-dev libreadline-dev libsqlite3-dev wget curl llvm \
libncursesw5-dev xz-utils tk-dev libxml2-dev libxmlsec1-dev libffi-dev liblzma-dev \
python-dev python3-dev
Instala la última versión estable de Python que sea aceptada en el currículum de Le Wagon:
pyenv install 3.8.12
Este comando puede tomar un tiempo en ejecutarse. Esto es completamente normal. ¡No dudes en ayudar a los estudiantes que estén sentados cerca de ti!
OK. Cuando este comando termine de ejecutarse, le diremos al sistema que use esta versión de Python por defecto. Esto se hace con:
pyenv global 3.8.12
exec zsh
Para verificar que esto haya funcionado, ejecuta python --version
. Si ves 3.8.12
, ¡todo está bien! Si no, pídele ayuda a un TA para resolver el problema por medio de versiones de pyenv
y type -a python
(python
debería estar usando la versión .pyenv/shims
de primero).
DDescarga e instala DBeaver, una herramienta poderosa, gratuita y de código abierto para conectar con cualquier base de datos, explorar su esquema e incluso hacer consultas SQL.
Si no sabes que hacer, haz clic en este enlace. Si ya iniciaste sesión, puedes omitir esta sección. Si no, haz clic en Enter Kitt as a Student
. Esto significa iniciar sesión como estudiante. Si no tienes problemas para iniciar sesión, puedes omitir este paso. De lo contrario pídele a un profesor que te confirme si debiste haber recibido o si debes seguir las instrucciones de aquí abajo.
Registrate como alumni de Le Wagon yendo a kitt.lewagon.com/onboarding. Selecciona tu batch, inicia sesión con GitHub y completa toda la información que te piden.
Ahora tu profesor podrá validar que realmente eres parte del batch. Pídele que lo haga justo después de que hayas completado el formulario de registro.
Cuando el profesor haya aprobado tu perfil, ve a la bandeja de entrada de tu email. Deberías tener 2 nuevos emails:
- Uno de Slack, invitándote a la comunidad de los alumni de Le Wagon en slack (donde podrás chatear con tus compañeros y todos los demás alumni). Haz clic en Join y completa la información que te piden.
- Otro de GitHub, invitándote a
lewagon
team. Acéptala, de lo contrario no podrás acceder a las diapositivas de las clases.