Add instructions for compiling graphql-engine natively on M1

PR-URL: https://github.com/hasura/graphql-engine-mono/pull/2049
GitOrigin-RevId: 9f10c26eef5382fb7b8e750ad272a5797b4cd6d8
This commit is contained in:
Gil Mizrahi 2021-11-24 11:58:10 +02:00 committed by hasura-bot
parent 020198969f
commit 6dae132fce
5 changed files with 134 additions and 5 deletions

View File

@ -19,6 +19,13 @@ MSSQL_CONTAINER_NAME="hasura-dev-mssql-$MSSQL_PORT"
MSSQL_CONN_STR="DRIVER={ODBC Driver 17 for SQL Server};SERVER=127.0.0.1,$MSSQL_PORT;Uid=sa;Pwd=$MSSQL_PASSWORD;" MSSQL_CONN_STR="DRIVER={ODBC Driver 17 for SQL Server};SERVER=127.0.0.1,$MSSQL_PORT;Uid=sa;Pwd=$MSSQL_PASSWORD;"
MSSQL_DOCKER="docker exec -it $MSSQL_CONTAINER_NAME sqlcmd -S localhost -U sa -P $MSSQL_PASSWORD" MSSQL_DOCKER="docker exec -it $MSSQL_CONTAINER_NAME sqlcmd -S localhost -U sa -P $MSSQL_PASSWORD"
if [[ `uname -m` == 'arm64' ]]; then
MSSQL_PLATFORM=linux/arm64
MSSQL_CONTAINER_IMAGE=mcr.microsoft.com/azure-sql-edge
else
MSSQL_PLATFORM=linux/amd64
MSSQL_CONTAINER_IMAGE=hasura/mssql-server-2019-cu10-ubuntu-20.04:latest
fi
###################### ######################
# Functions # # Functions #
@ -27,7 +34,9 @@ MSSQL_DOCKER="docker exec -it $MSSQL_CONTAINER_NAME sqlcmd -S localhost -U sa -P
function mssql_launch_container(){ function mssql_launch_container(){
echo_pretty "Launching MSSQL container: $MSSQL_CONTAINER_NAME" echo_pretty "Launching MSSQL container: $MSSQL_CONTAINER_NAME"
docker run --name $MSSQL_CONTAINER_NAME \ docker run --name $MSSQL_CONTAINER_NAME \
-p 127.0.0.1:"$MSSQL_PORT":1433 -d hasura/mssql-server-2019-cu10-ubuntu-20.04:latest --platform "$MSSQL_PLATFORM" \
-e ACCEPT_EULA=1 \
-p 127.0.0.1:"$MSSQL_PORT":1433 -d "$MSSQL_CONTAINER_IMAGE"
} }
function mssql_wait { function mssql_wait {

View File

@ -19,6 +19,8 @@ MYSQL_PASSWORD=hasuraMySQL1
MYSQL_CONTAINER_NAME="hasura-dev-mysql-$MYSQL_PORT" MYSQL_CONTAINER_NAME="hasura-dev-mysql-$MYSQL_PORT"
# space deliberately omitted between -u and -p params https://hub.docker.com/_/mysql # space deliberately omitted between -u and -p params https://hub.docker.com/_/mysql
MYSQL_DOCKER="docker exec -it $MYSQL_CONTAINER_NAME mysql -u$MYSQL_USER -p$MYSQL_PASSWORD" MYSQL_DOCKER="docker exec -it $MYSQL_CONTAINER_NAME mysql -u$MYSQL_USER -p$MYSQL_PASSWORD"
MYSQL_CONTAINER_IMAGE=mysql:8.0
MYSQL_PLATFORM=linux/amd64 # for M1 arch we use the rosetta emulation
###################### ######################
# Functions # # Functions #
@ -29,8 +31,9 @@ function mysql_launch_container(){
docker run --name $MYSQL_CONTAINER_NAME \ docker run --name $MYSQL_CONTAINER_NAME \
-e MYSQL_ROOT_PASSWORD=$MYSQL_PASSWORD \ -e MYSQL_ROOT_PASSWORD=$MYSQL_PASSWORD \
-e MYSQL_DATABASE=hasura \ -e MYSQL_DATABASE=hasura \
--platform "$MYSQL_PLATFORM" \
-p 127.0.0.1:$MYSQL_PORT:3306 \ -p 127.0.0.1:$MYSQL_PORT:3306 \
-d mysql:8.0 -h "127.0.0.1" -d "$MYSQL_CONTAINER_IMAGE" -h "127.0.0.1"
} }
function mysql_wait { function mysql_wait {

View File

@ -15,9 +15,15 @@ fi
PG_PASSWORD=postgres PG_PASSWORD=postgres
PG_CONTAINER_NAME="hasura-dev-postgres-$PG_PORT" PG_CONTAINER_NAME="hasura-dev-postgres-$PG_PORT"
PG_DB_URL="postgres://postgres:$PG_PASSWORD@127.0.0.1:$PG_PORT/postgres" PG_DB_URL="postgresql://postgres:$PG_PASSWORD@127.0.0.1:$PG_PORT/postgres"
PG_DOCKER="docker exec -u postgres -it $PG_CONTAINER_NAME psql $PG_DB_URL" PG_DOCKER="docker exec -u postgres -it $PG_CONTAINER_NAME psql $PG_DB_URL"
if [[ `uname -m` == 'arm64' ]]; then
PG_CONTAINER_IMAGE=sayitsocial/postgis:raspi
else
PG_CONTAINER_IMAGE=circleci/postgres:11.5-alpine-postgis
fi
# NOTE FWIW: # NOTE FWIW:
# Brandon tried these options to speed up integration tests, but to little effect: # Brandon tried these options to speed up integration tests, but to little effect:
# fsync=off # fsync=off
@ -66,7 +72,7 @@ function pg_launch_container(){
-p 127.0.0.1:"$PG_PORT":$PG_PORT \ -p 127.0.0.1:"$PG_PORT":$PG_PORT \
--expose="$PG_PORT" \ --expose="$PG_PORT" \
-e POSTGRES_PASSWORD="$PG_PASSWORD" \ -e POSTGRES_PASSWORD="$PG_PASSWORD" \
-d circleci/postgres:11.5-alpine-postgis \ -d "$PG_CONTAINER_IMAGE" \
$CONF_FLAGS $CONF_FLAGS
# graphql-engine calls the pg_dump executable. To avoid a version mismatch (and # graphql-engine calls the pg_dump executable. To avoid a version mismatch (and

View File

@ -202,7 +202,17 @@ function pg_start() {
function mssql_start() { function mssql_start() {
mssql_launch_container mssql_launch_container
MSSQL_RUNNING=1 MSSQL_RUNNING=1
mssql_wait if [[ `uname -m` == 'arm64' ]]; then
# mssql_wait uses the tool sqlcmd to wait for a database connection which unfortunately
# is not available for the azure-sql-edge docker image - which is the only image from microsoft
# that runs on M1 computers. So we sleep for 20 seconds, cross fingers and hope for the best
# see https://github.com/microsoft/mssql-docker/issues/668
echo "Sleeping for 20 sec while mssql comes up..."
sleep 20
else
mssql_wait
fi
} }
function citus_start() { function citus_start() {

101
server/COMPILING-ON-M1.md Normal file
View File

@ -0,0 +1,101 @@
# Compile a native arm64 graphql-engine executable on M1 using brew and ghc-8.10.7
1. Install ghc-8.10.7 and cabal-install via ghcup
2. Install dependencies:
```sh
brew install google-cloud-sdk
brew install node@14
brew install openssl
brew install pcre
brew install unixodbc
brew install libpq
brew install mysql-client@5.7
brew install libffi
brew install llvm@11
```
And add them to your environment:
```sh
echo 'export PATH="/opt/homebrew/Caskroom/google-cloud-sdk/latest/google-cloud-sdk/bin:$PATH"' >> ~/.zshrc
echo 'export PATH="/opt/homebrew/opt/openssl@1.1/bin:$PATH"' >> ~/.zshrc
echo 'export PATH="/opt/homebrew/opt/node@14/bin:$PATH"' >> ~/.zshrc
echo 'export PATH="/opt/homebrew/opt/mysql-client@5.7/bin:$PATH"' >> ~/.zshrc
echo 'export PATH="/opt/homebrew/opt/libpq/bin:$PATH"' >> ~/.zshrc
echo 'export PATH="/opt/homebrew/opt/llvm@11/bin:$PATH"' >> ~/.zshrc
```
3. Install console assets
```sh
cd console
npm ci
npm run server-build
cd ..
```
4. Install python
```sh
export PKG_CONFIG_PATH="/opt/homebrew/opt/libffi/lib/pkgconfig"
export LDFLAGS="-L/opt/homebrew/opt/openssl@1.1/lib"
cd server
python3 -m venv .python-venv
source .python-venv/bin/activate
pip3 install -r tests-py/requirements.txt
(cd tests-py/remote_schemas/nodejs && npm ci)
```
5. Add the C dependencies in the `cabal.project.dev-sh.local` and `cabal.project.local` files (according to where the dependencies were installed by homebrew):
```sh
package mysql
extra-include-dirs:
/opt/homebrew/opt/openssl/include
/opt/homebrew/opt/mysql-client@5.7/include
extra-lib-dirs:
/opt/homebrew/opt/openssl/lib
/opt/homebrew/opt/mysql-client@5.7/lib
package odbc
extra-include-dirs: /opt/homebrew/opt/unixodbc/include
extra-lib-dirs: /opt/homebrew/opt/unixodbc/lib
package pcre-light
extra-include-dirs: /opt/homebrew/opt/pcre/include
extra-lib-dirs: /opt/homebrew/opt/pcre/lib
package postgresql-libpq
extra-include-dirs:
/opt/homebrew/opt/libpq/include
/opt/homebrew/opt/openssl/include
extra-lib-dirs:
/opt/homebrew/opt/libpq/lib
/opt/homebrew/opt/openssl/lib
package pg-client
extra-include-dirs:
/opt/homebrew/opt/libpq/include
/opt/homebrew/opt/openssl/include
extra-lib-dirs:
/opt/homebrew/opt/libpq/lib
/opt/homebrew/opt/openssl/lib
```
Note: If you don't have special requirements of a `cabal.project.local` you can just add a symbolic link to `cabal.project.dev-sh.local`:
```sh
ln -s cabal.project.dev-sh.local cabal.project.local
```
6. Building the server should now work:
```sh
cabal v2-update
cabal v2-build graphql-engine -j4
```