Create a production build locally
Edit this page
Learn how to create a production build for your Expo app locally.
To create your app's production build (also known as release build) locally, you need to follow separate steps on your computer and use the tools required to create any native app. This guide provides the necessary steps for Android and iOS.
Android
Creating a production build locally for Android requires signing it with an upload key and generating an Android Application Bundle (.aab). Follow the steps below:
Prerequisites
- OpenJDK distribution installed to access the
keytool
command - android directory generated. If you are using CNG, then run
npx expo prebuild
to generate it.
1
Create an upload key
Already created a build with EAS Build? Download your credentials and skip to the next step.
If you've already created a build with EAS Build, follow the steps below to download the credentials, which contains the upload key and its password, key alias, and key password:
- In your terminal, run
eas credentials -p android
and select the build profile. - Select credentials.json > Download credentials from EAS to credentials.json.
- Move the downloaded keystore.jks file to the android/app directory.
- Copy the values for the upload keystore password, key alias, and key password from the credentials.json as you will need them in the next step.
Inside your Expo project directory, run the following keytool
command to create an upload key:
-
sudo keytool -genkey -v -keystore my-upload-key.keystore -alias my-key-alias -keyalg RSA -keysize 2048 -validity 10000
After running this command, you will be prompted to enter a password for the keystore. This password will protect the upload key. Remember the password you enter here, as you'll need it in the next step.
This command also generates the keystore file named my-upload-key.keystore in your project directory. Move it to the android/app directory.
If you commit the android directory to a version control system like Git, don't commit this keystore file. It contains your upload key and should be kept private.
2
Update gradle variables
Open android/gradle.properties file and add the following gradle variables at the end of the file. Replace the *****
with the correct keystore and key password that you provided in the previous step.
These variables contain information about your upload key:
MYAPP_UPLOAD_STORE_FILE=my-upload-key.keystore
MYAPP_UPLOAD_KEY_ALIAS=my-key-alias
MYAPP_UPLOAD_STORE_PASSWORD=*****
MYAPP_UPLOAD_KEY_PASSWORD=*****
If you commit the android directory to a version control system like Git, don't commit the above information. Instead, create a ~/.gradle/gradle.properties file on your computer and add the above variables to this file.
3
4
Generate release Android Application Bundle (aab)
Navigate inside the android directory and create a production build in .aab format by running Gradle's bundleRelease
command:
-
cd android
-
./gradlew app:bundleRelease
This command will generate app-release.aab inside the android/app/build/outputs/bundle/release directory.
5
Manual app submission to Google Play Console
Google Play Store requires manual app submission when submitting the .aab file for the first time.
Follow the steps from the FYI guide on manually submitting your app to Google Play Store for the first time.
iOS
To create an iOS production build locally for Apple App Store, you need to use Xcode which handles the signing and submission process via App Store Connect.
Prerequisites
- Paid Apple Developer membership
- Xcode installed on your computer
- ios directory generated. If you are using CNG, then run
npx expo prebuild
to generate it.
1
Open iOS workspace in Xcode
Inside your Expo project directory, run the following command to open your-project.xcworkspace
in Xcode:
-
xed ios
After opening the iOS project in Xcode:
- From the sidebar on the left, select your app's workspace.
- Go to Signing & Capabilities and select All or Release.
- Under Signing > Team, ensure your Apple Developer team is selected. Xcode will generate an automatically managed Provisioning Profile and Signing Certificate.
2
3
4
App submission using App Store Connect
Once the build is complete, you can distribute your app to TestFlight or submit it to the App Store using App Store Connect:
- From the menu bar, open Product > Archive.
- Under Archives, click Distribute App from the right sidebar.
- Click App Store Connect and follow the prompts shown in the window. This step will create an app store record and upload your app to the App Store.
- Now you can go to your App Store Connect account, select your app under Apps, and submit it for testing using TestFlight or prepare it for final release by following the steps in the App Store Connect dashboard.