Skip to content

Commit

Permalink
Documenting build process
Browse files Browse the repository at this point in the history
Building this library started breaking when we introduced the M1
laptops. Initially it appeared to be an issue with the new instruction
set, however, builds failed on linux as well. The main issue was that
the build procedure was not properly documented.

Due to that, header files and shared libraries could not be found, and
even after rectifying this, a preprocessor define (`THREADED`) was
missing the compiler couldn't resolve all the symbols.

This commit updates the README with necessary instructions on how to
build, and adds CGO flags specifically for building on the new M1
macbooks.  Further it adds a `go.mod` file to properly declare
dependencies.
  • Loading branch information
ilikeorangutans committed Jan 5, 2022
1 parent 2db116d commit d003a3c
Show file tree
Hide file tree
Showing 6 changed files with 78 additions and 11 deletions.
1 change: 1 addition & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,4 @@ _*
[568].out
*.cgo*.c
*.cgo*.go
tags
4 changes: 0 additions & 4 deletions README

This file was deleted.

64 changes: 64 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
# gozk - Go zookeeper library via C bindings

Forked from https://github.com/youtube/vitess/tree/master/third_party/go/launchpad.net/gozk/zookeeper

## Requirements

- zookeeper c library headers: when installed via homebrew you'll find the includes under `/opt/homebrew/include` and the shared libraries in `/opt/homebrew/lib/`. Other
systems such as Linux use different paths but are likely to place them under `/usr/include` and `/usr/lib`.
- C compiler

If you zookeeper includes and shared libraries are not in the default search locations (`/usr/include` and `/usr/lib`) you'll have to set environment variables to point
the compiler at the right path. For example when using homebrew, you'll need to specify:

```
export CGO_CFLAGS='-I/opt/homebrew/include/zookeeper'
export CGO_LDFLAGS='-L/opt/homebrew/lib'
```

On Debian Linux, used by the official go docker container, you'll needthe following libraries:

* `libzookeeper-mt-dev`: header files
* `libzookeeper-mt2`: shared libraries

Set the `CGO` flags:

```
export CGO_CFLAGS='-I/usr/include/zookeeper'
export CGO_LDFLAGS='-L/usr/lib/aarch64-linux-gnu'
```

Then:

```
go build
```

### Build Errors

#### `zookeeper.h` not found
Error message looks like this:
```
./zk.go:21:11: fatal error: zookeeper.h: No such file or directory
21 | // #include <zookeeper.h>
| ^~~~~~~~~~~~~
compilation terminated.
```

The include search path does not include the zookeeper includes. Check that `CGO_CFLAGS=-I` is set to a directory that contains the zookeeper includes.

#### `ld: library not found`
Error message:
```
ld: library not found for -lzookeeper_mt
collect2: error: ld returned 1 exit status
```

The linker can't find the shared library. Ensure that `CGO_LDFLAGS=-L` points to a directory that contains the zookeeper libraries.

## Historic Notes

Check out https://wiki.ubuntu.com/gozk

Forked from https://github.com/youtube/vitess/tree/master/third_party/go/launchpad.net/gozk/zookeeper
to fix panic issues in some of the watch functions.
5 changes: 5 additions & 0 deletions go.mod
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
module github.com/Shopify/gozk

go 1.16

require launchpad.net/gocheck v0.0.0-20140225173054-000000000087
2 changes: 2 additions & 0 deletions go.sum
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
launchpad.net/gocheck v0.0.0-20140225173054-000000000087 h1:Izowp2XBH6Ya6rv+hqbceQyw/gSGoXfH/UPoTGduL54=
launchpad.net/gocheck v0.0.0-20140225173054-000000000087/go.mod h1:hj7XX3B/0A+80Vse0e+BUHsHMTEhd0O4cpUHr/e/BUM=
13 changes: 6 additions & 7 deletions zk.go
Original file line number Diff line number Diff line change
Expand Up @@ -8,13 +8,12 @@
//
package zookeeper

/*
#cgo CFLAGS: -I/usr/include/c-client-src -I/usr/include/zookeeper
#cgo LDFLAGS: -lzookeeper_mt
#include <zookeeper.h>
#include "helpers.h"
*/
// #cgo CFLAGS: -DTHREADED -I/usr/include/zookeeper
// #cgo arm64 darwin CFLAGS: -DTHREADED -I/opt/homebrew/include/zookeeper
// #cgo LDFLAGS: -lzookeeper_mt
//
// #include <zookeeper.h>
// #include "helpers.h"
import "C"

import (
Expand Down

0 comments on commit d003a3c

Please sign in to comment.