TinyTds :: Ошибка: имя сервера не найдено в файлах конфигурации - PullRequest
0 голосов
/ 29 октября 2019

Я использую Docker + Rails + Tiny TDS в Windows. Эта конфигурация работала отлично, пока я не начал докеризацию среды. Буду признателен за любую оказанную помощь.

Gemfile

gem 'tiny_tds'
gem 'rails', '4.2.8'

DockerFile

FROM ruby:2.4.0
RUN apt-get update -qq && apt-get install -y nodejs postgresql-client
RUN apt-get update && apt-get install -y dos2unix
RUN apt-get update && apt-get install -yq freetds-bin    

RUN mkdir /myapp
WORKDIR /myapp
ADD Gemfile /myapp/Gemfile
ADD Gemfile.lock /myapp/Gemfile.lock

RUN bundle install
COPY . /myapp

# Add a script to be executed every time the container starts.
COPY entrypoint.sh /usr/bin/

# Start the main process.

RUN dos2unix entrypoint.sh && apt-get --purge remove -y dos2unix && rm -rf /var/lib/apt/lists/*


EXPOSE 3000

Docker-compose.yml

version: '3'

services:
  db:
    image: postgres:12-alpine

  redis:
    image: redis:alpine
  server:
    tty: true
    stdin_open: true
    build: .
    command: bash -c "rm -f tmp/pids/server.pid && rake db:create && rake db:migrate &&  bundle exec rails s -p 3000 -b '0.0.0.0'"
    links:
      - db
      - redis

    volumes:
        # - ./tmp/db:/var/lib/postgresql/data
         - .:/usr/src/app
        #    - .:/myapp
    ports:
      - "3000:3000"
      - "1433:1433"
      - "1434:1434"

    environment:

      DATABASE_URL: postgres://postgres@db:5432/app?pool=25&encoding=unicode&schema_search_path=public
      # DEVISE_JWT_SECRET_KEY: RANDOM_SECRET
      REDIS_URL: redis://redis:6379

Когда я проверяю соединение

    client = TinyTds::Client.new username: 'sa',
    password: 'password',
    port: 1433,
    host: 'server_name', # works if you are not using docker
    # dataserver: 'server_name', #This did not work as well
    timeout: 10000

Сообщение об ошибке:

TinyTds :: Ошибка: имя сервера не найдено в файлах конфигурации из /usr/local/bundle/gems/tiny_tds-1.0.4/lib/tiny_tds/client. rb: 43: в `connect '

Любая помощь очень ценится.

1 Ответ

0 голосов
/ 30 октября 2019

Согласно комментарию @ lyzard-kyng к вопросу, IP-адрес помог диагностировать проблему. Свойства DNS-суффикса управлялись окнами. Я должен был добавить их к имени_сервера.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...