Avito на GopherCon Russia 2018

Всем привет! В марте в московском Технополисе прошла конференция, посвященная языку программирования Go — GopherCon Russia 2018. На ней прозвучали выступления от core-team — было круто услышать из первых уст о том, как нужно делать правильно. И конечно, не обошлось без докладов про микросервисы, опентрейсинг, работу с сетью в Go, создание клиентских библиотек и крутых инструментов.
Хотим сказать «спасибо» выступающим — за доклады и организаторам — за возможность пообщаться с живым Бредом Фитцпатриком и настоящей Эшли МакНамара. Под катом рассказываем о докладах, мастер-классах и конкурсе от Avito, а также разыгрываем немного Go-сувенирки.


7wht59ndvnwdxrwfvkuiki9l60g.png


Большинство фото мы взяли из отчета, выложенного на странице GopherCon Russia 2018 в Facebook.


Доклады & секции от Avito

Строим поисковую экосистему на Go


В своем докладе Андрей Дроздов рассказывал об устройстве поисковых движков на живых примерах, о том, что уже сделано в Go-сообществе на эту тему, сравнивал производительность «самопального» поискового движка на Go и решения на фреймворке riot. В ходе доклада обсудили, как строить поисковую инфраструктуру в компании и быстро вводить в эксплуатацию новые алгоритмы поиска. Слайды с множеством полезных ссылок лежат здесь.


bgi2fdscqpxzlqxcjjuwshldnb4.jpeg


Поиск на миллион


В продолжение своего доклада Андрей Дроздов провел мастер-класс, где можно было попрактиковаться в создании поисковых систем.
Вот что он рассказывает про встречу:


Несмотря на небольшие проблемы с подключением компьютера на мастер-классе было много людей. Большая часть смогла написать свой поиск на фреймворке riot, загрузить в него миллион новостных заголовков и получить в подарок наклейки от Авито). Трое самых активных помимо основной задачи решили несколько дополнительных: провели свой бенчмарк и реализовали кастомный ранкер. Я буду рад, если в итоге больше людей изучат riot и, возможно, законтрибьютят в него, чтобы он развивался быстрее.


Centrifugo 2


В рамках секции внутри Avito-комнаты Александр Емелин рассказывал о планах дальнейшего развития проекта Centrifugo. Последние несколько месяцев он работал над второй версией сервера, позволяющего обслуживать тысячи одновременных подключений от пользователей приложения и отправлять им сообщения в режиме реального времени (Websocket и SockJS). Важной особенностью сервера является то, что он позволяет интегрироваться с бекендом, написанным на любом языке программирования.


Во второй версии были реализованы достаточно сложные задачи — например, ядро сервера было выделено в отдельную библиотеку, которую смогут использовать Go-разработчики. Реализована поддержка передачи бинарных данных по Websocket (Protobuf) в дополнение к имеющемуся JSON-протоколу, а также реализована поддержка GRPC в качестве альтернативного транспорта.


Вот что рассказал Александр после мастер-класса:


В Avito-комнату пришло достаточно много людей, среди которых были и текущие пользователи Centrifugo. Получилось получить ценный фидбек, что чрезвычайно важно на данной стадии разработки. После устного рассказа про особенности второй версии посмотрели на небольшой real-time пример, использующий эту библиотеку — очень простой чат с интересной особенностью: сервер позволял клиентам использовать не только протокол Websocket в качестве транспорта, но и GRPC.


Golang, или Туда и Обратно

На нашем стенде, конечно, тоже целый день было людно. Уже в ∞ утра мы ждали самых ранних участников конференции. Можно было сфотографироваться с Гофером…


vm1wjynrvdiv94wqv4hp_ur2lwq.jpeg


… Или бравым сотрудником нашего отдела технопиара Гошей Бессмертным, который совсем недавно был принят в штат младшим специалистом (правда, пока только в качестве инвентарного номера)…


v2pswn5yw4h8fr3dhs4-vb90kkc.jpeg


Ну и самая, пожалуй, интересная активность — весь день на нашем стенде проходил конкурс «Golang, или Туда и Обратно», где можно выиграть футболку, варежки или стикерпак с символикой Go. Нужно было сопоставить сниппеты кода, написанного на Golang и других языках программирования. Если приглядеться, то можно увидеть, как примерно половина запечатлённых на этом снимке участников конференции вовсю матчит сниппеты:


xtcx0fgvfmbughrtdu2pfym009s.jpeg


А вот планы покрупнее:


uimrmf7erwfjcqq6bqfplqqt9fe.png


И немножко — в залах докладов:


yxqnhczcuwzfu39afg7eanv_jge.png


Кажется, что игра «зашла» всем участникам: те, кто участвовал в конкурсе, с удовольствием размяли мозги перед докладами и в перерывах между ними, а мы получили удовольствие от общения с каждым из примерно 350 участников этой игры.


Розыгрыш стикерпаков и Go-варежек на Хабре

У нас осталось некоторое количество Go-варежек и стикерпаков — их мы хотим разыграть здесь, на Хабре. Что внутри набора наклеек? Девять «базовых» гоферов…


6jmy5lusuw5pi6wwzqwgbvfwqa4.jpeg


… и набор наклеек-аксессуаров к ним для того, чтобы вы могли собрать своего собственного гофера. Например, так:


tavugyb5ykf3wgbo71y7tov_w-o.png


Для этого предлагаем вам посмотреть и сопоставить сниппеты кода, написанного на Golang и других языках программирования. И написать в комментариях пары по принципу 1 — A, 2 — B и так далее. Прячьте ответы под спойлер, чтобы не портить другим фан!


Первым пяти комментаторам мы пришлём по Go-стикерпаку и паре варежек почтой или курьером. Ещё пять таких же наборов распределим между оставшимися участниками с помощью рэндомайзера. Enjoy!


Развернуть примеры кода

1
no8ekwmospwkegwijdjou4vtpge.png


2
xm0co7etslilyfg0polco8spwfo.png


3
1cft2e8ytqtpvpmeeokpuc80yq0.png


4
fg7z4uxsb5h96vrmcxcbbynzeuc.png


5
ydnliqzacsuqrtq6lsqlzdri64q.png


6
nfbq8lqran_wkv5wr7k8izkhdz8.png


7
svwycbi3pjsofwgme8nvd1d8gpu.png


8
v3pkz320bcwio3kli1smytxts74.png


9
3kst6p0cdblhq04lglyqiqpy_kw.png


10
kzpnsok2zbzkrdzzjxi3kuvjef4.png


A


type vertex struct {
        X, Y int
}

func f(v *vertex) {
        v.X = 3
        v.Y = 4
}

func main() {
        v1 := vertex{1, 8}
        f(&v1)
}

B


package main

import "fmt"
import "math"

func main() {
        fmt.Printf("%f", 1.0/math.Sqrt(49))
}

C


package main

import (
    "fmt"
    "unicode/utf8"
)

func main() {
    b := []byte{80, 72, 80, 32, 114, 117, 108, 101, 115}
    for len(b) > 0 {
        r, size := utf8.DecodeRune(b)
        fmt.Printf("%c", r)
        b = b[size:]
    }
}

D


func f(x, y int64) int64 {
   return x + y
}

E


package main

import (
        "fmt"
)

func f(a int) func(b int) int {
        return func(b int) int {
                return a*b
        }
}

func main() {
        list := []int{2, 2, 2, 2}
        g := f(3)
        for i, value := range list {
                list[i] = g(value)
        }
        fmt.Println(list)
}

F


type vt struct {
        X, Y int
}

func f(v vt) {
        v.X = 3
        v.Y = 4
}

func main() {
        v1 := vt{1, 8}
        f(v1)
}

G


package main

import (
        "io"
        "log"
        "net/http"
)

func h(w http.ResponseWriter, r *http.Request) {
        io.WriteString(w, "hello, world!\n")
}

func main() {
        http.HandleFunc("/", h)
        log.Fatal(http.ListenAndServe(":8080", nil))
} 

H


type filter func(string) bool

func bf(list []string, fn filter) [][]string {
        valid, invalid := []string{}, []string{}

        for _, s := range list {
                if fn(s) {
                        valid = append(valid, s)
                } else {
                        invalid = append(invalid, s)
                }
        }

        return [][]string{valid, invalid}
}

func main() {
        l := []string{"gl", "hf", "ht", "tt"}

        res := bf(l, func(s string) bool {
                return s[0] == 'h'
        })
}

I


package main

import "fmt"

func main() {
        a, b := 5, 10
        fmt.Println(map[bool]int{true: a, false: a-1}[a > b])
}

J


package main

import (
        "fmt"
)

func f(a, b int) int {
        if a > b {
                return a
        }

        return b
}

func main() {
        ints := []int{1, 8, 3, 4, 5}
        res := ints[0]

        for _, v := range ints {
                res = f(res, v)
        }

        fmt.Println(res)
}


Ждём ваших комментариев! А Гофер пока отдыхает после конференции и набирается сил перед следующей.


34ntb4jzk6fvq3m04hlqawheymu.jpeg


До новых встреч!

© Habrahabr.ru