本地部署Grok-1

1.环境准备

  • 操作系统: Ubuntu 20.04.1 LTS
  • CPU: 128C
  • Memroy: 1T
  • Disk: 10T
  • GPU: NVIDIA A800-SXM4-80GB * 8
  • 驱动: Driver Version: 530.30.02 CUDA Version: 12.1

2.下载

  • 代码下载

    git clone https://github.com/xai-org/grok-1.git
    cd grok-1
    pip install -r requirements.txt  -i https://pypi.tuna.tsinghua.edu.cn/simple
    mkdir checkpoints/ckpt-0
    
  • 模型下载

    huggingface-cli 下载到99%总是卡住,直接使用wget下载

    sh urls.sh #见下方
    nohup sh  download.sh   > log 2>& 1 &
    
  • url.sh

    #/bin/bash
      
    echo "#/bin/bash" > download.sh
    for i in {0..769}
    do
       seq="tensor0000"$i"_000"
       if [ $i -ge 10 ]
       then
              seq="tensor000"$i"_000"
       fi
       if [ $i -ge 100 ]
       then
              seq="tensor00"$i"_000"
       fi
       echo "wget -O checkpoints/ckpt-0/$seq  https://hf-mirror.com/xai-org/grok-1/resolve/main/ckpt-0/$seq?download=true " >> download.sh
    done
    

3. 运行使用

  • 测试jax是否可用

    import torch,jax
    print(torch.cuda.is_available());
    print(jax.devices())
    
  • 修改run.py

     64     gen = inference_runner.run()
     65 
     66     #inp = "The answer to life the universe and everything is of course"
     67     inp = "write quick sort with golang" # 输入自定义的prompt
     68     # print(f"Output for prompt: {inp}", sample_from_model(gen, inp, max_len=100, temperature=0.01)) 
     69     print(f"Output for prompt: {inp}", sample_from_model(gen, inp, max_len=300, temperature=0.01))  #max_len修改大一点
     70 
     71 if __name__ == "__main__":
     72     logging.basicConfig(level=logging.INFO)
     73     main()
    

    prompt: write quick sort with golang

    output:

    image-grok-output.png

  • GPU 资源使用

    image-grok-1-gpu.png

4.TODO

构建成serving

5.常见问题

问题1

  • 现象

    INFO:jax._src.xla_bridge:Unable to initialize backend 'cuda': 
    INFO:jax._src.xla_bridge:Unable to initialize backend 'rocm': module 'jaxlib.xla_extension' has no attribute 'GpuAllocatorConfig'
    INFO:jax._src.xla_bridge:Unable to initialize backend 'tpu': INTERNAL: Failed to open libtpu.so: libtpu.so: cannot open shared object file: No such fil
    e or directory
    WARNING:jax._src.xla_bridge:An NVIDIA GPU may be present on this machine, but a CUDA-enabled jaxlib is not installed. Falling back to cpu.
    INFO:rank:Initializing mesh for self.local_mesh_config=(1, 8) self.between_hosts_config=(1, 1)...
    INFO:rank:Detected 1 devices in mesh
    Traceback (most recent call last):
      File "/data/grok-1/run.py", line 72, in <module>
        main()
      File "/data/grok-1/run.py", line 63, in main
        inference_runner.initialize()
      File "/data/grok-1/runners.py", line 282, in initialize
        runner.initialize(
      File "/data/grok-1/runners.py", line 181, in initialize
        self.mesh = make_mesh(self.local_mesh_config, self.between_hosts_config)
                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/data/grok-1/runners.py", line 586, in make_mesh
        device_mesh = mesh_utils.create_hybrid_device_mesh(
                      ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/data/miniconda3/lib/python3.12/site-packages/jax/experimental/mesh_utils.py", line 373, in create_hybrid_device_mesh
        per_granule_meshes = [create_device_mesh(mesh_shape, granule)
                              ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
      File "/data/miniconda3/lib/python3.12/site-packages/jax/experimental/mesh_utils.py", line 302, in create_device_mesh
        raise ValueError(f'Number of devices {len(devices)} must equal the product '
    ValueError: Number of devices 1 must equal the product of mesh_shape (1, 8)
    
  • 解决办法: 修改requirements.txt

    dm_haiku==0.0.12
    jax[cuda12]==0.4.25 -f https://storage.googleapis.com/jax-releases/jax_cuda_releases.html
    numpy==1.26.4
    sentencepiece==0.2.0
    
    
    

问题2

  • 现象

    2024-03-21 15:27:29.467666: E external/xla/xla/stream_executor/cuda/cuda_driver.cc:280] failed call to cuInit: CUDA_ERROR_NOT_INITIALIZED: initialization error
    Traceback (most recent call last):
      File "/data/miniconda3/envs/grok/lib/python3.10/site-packages/jax/_src/xla_bridge.py", line 694, in backends
        backend = _init_backend(platform)
      File "/data/miniconda3/envs/grok/lib/python3.10/site-packages/jax/_src/xla_bridge.py", line 776, in _init_backend
        backend = registration.factory()
      File "/data/miniconda3/envs/grok/lib/python3.10/site-packages/jax/_src/xla_bridge.py", line 514, in factory
        return xla_client.make_c_api_client(plugin_name, options, None)
      File "/data/miniconda3/envs/grok/lib/python3.10/site-packages/jaxlib/xla_client.py", line 197, in make_c_api_client
        return _xla.get_c_api_client(plugin_name, options, distributed_client)
    jaxlib.xla_extension.XlaRuntimeError: FAILED_PRECONDITION: No visible GPU devices.
    
    During handling of the above exception, another exception occurred:
    
    Traceback (most recent call last):
      File "/data/grok-1/testgpu.py", line 3, in <module>
        print(jax.devices())
      File "/data/miniconda3/envs/grok/lib/python3.10/site-packages/jax/_src/xla_bridge.py", line 887, in devices
        return get_backend(backend).devices()
      File "/data/miniconda3/envs/grok/lib/python3.10/site-packages/jax/_src/xla_bridge.py", line 821, in get_backend
        return _get_backend_uncached(platform)
      File "/data/miniconda3/envs/grok/lib/python3.10/site-packages/jax/_src/xla_bridge.py", line 801, in _get_backend_uncached
        bs = backends()
      File "/data/miniconda3/envs/grok/lib/python3.10/site-packages/jax/_src/xla_bridge.py", line 710, in backends
        raise RuntimeError(err_msg)
    RuntimeError: Unable to initialize backend 'cuda': FAILED_PRECONDITION: No visible GPU devices. (you may need to uninstall the failing plugin package, or set JAX_PLATFORMS=cpu to skip this backend.)
    
  • 解决办法: 安装cuDNN

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容