Skip to content

fix: sqlsrv default port cause connection refuse #7624

New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Merged

Conversation

puschie286
Copy link
Contributor

@puschie286 puschie286 commented Jun 26, 2023

Description
database connection is refused when using sqlsrv driver with default port.
fixed by ignoring the default port ( 1433 )

Checklist:

  • Securely signed commits
  • Component(s) with PHPDoc blocks, only if necessary or adds value
  • Unit testing, with >80% coverage
  • User guide updated
  • Conforms to style guide

Fixes: #6165
Related #6036

~ ignore default port when constructr hostname for sqlsrv driver
@datamweb
Copy link
Contributor

datamweb commented Jun 26, 2023

All code must conform to our Style Guide, which is based on PSR-12.
You can fix most of the coding style violations by running this command in your terminal:

composer cs-fix

more info here.

https://github.com/codeigniter4/CodeIgniter4/actions/runs/5380968061/jobs/9764425097

@kenjis kenjis added the tests needed Pull requests that need tests label Jun 26, 2023
@kenjis
Copy link
Member

kenjis commented Jun 26, 2023

What is the issue?
#6165 is not a bug.

We have tests with SQLSRV port 1433, and all tests pass.

'SQLSRV' => [
'DSN' => '',
'hostname' => 'localhost',
'username' => 'sa',
'password' => '1Secure*Password1',
'database' => 'test',
'DBDriver' => 'SQLSRV',
'DBPrefix' => 'db_',
'pConnect' => false,
'DBDebug' => true,
'charset' => 'utf8',
'DBCollat' => 'utf8_general_ci',
'swapPre' => '',
'encrypt' => false,
'compress' => false,
'strictOn' => false,
'failover' => [],
'port' => 1433,

~ add missing space (style guide)
@puschie286
Copy link
Contributor Author

puschie286 commented Jun 27, 2023

run tests on a windows server 2019 with default (ms sql server) installation with php 8.2 - all database test fail with the following exception:

CodeIgniter\Database\Exceptions\DatabaseException : Unable to connect to the database.
Main connection [SQLSRV]: [Microsoft][ODBC Driver 17 for SQL Server]TCP Provider: No connection could be made because the target machine actively refused it.
 SQLSTATE: 08001, code: 10061
[Microsoft][ODBC Driver 17 for SQL Server]Login timeout expired SQLSTATE: HYT00, code: 0
[Microsoft][ODBC Driver 17 for SQL Server]A network-related or instance-specific error has occurred while establishing a connection to SQL Server. Server is not found or not accessible. Check if instance name is correct and if SQL Server is configured to allow remote connections. For more information see SQL Server Books Online. SQLSTATE: 08001, code: 10061

So its not valid to add the default port for sqlsrv when executing on a windows platform.
@kenjis
To find problems like this, you need to add a test runner for windows platforms
( Beside there are many test that fail on windows server because of the line ending )

@kenjis
Copy link
Member

kenjis commented Jun 27, 2023

@puschie286 I got the error occurs only on Windows server.

I don't use Windows.
Contributions are welcome. See #7491

@michalsn
Copy link
Member

@puschie286 Stupid question... have you checked that the port number you are trying to use is correct? https://www.mssqltips.com/sqlservertip/2495/identify-sql-server-tcp-ip-port-being-used/

@puschie286
Copy link
Contributor Author

puschie286 commented Jun 28, 2023

@michalsn we use the default configuration, that is dynamic port ( Ref "By default, a SQL Server named instance is configured to listen on dynamic ports." ). this is probably the reason why the fixed port in the database config doesnt work with the default installation.

@kenjis to support dynamic ports, we could use 0 as dynamic port number ( because 0 is not valid as a port number, there shouldnt any conflicts with other database driver )

@michalsn
Copy link
Member

@puschie286 Ok, now I'm lost. If you're using dynamic ports, why are you expecting 1433 to work?

@puschie286
Copy link
Contributor Author

@michalsn you're right, for dynamic port we should remove the port config entry. guess thats the easiest solution

my concern is backward compatibility, some older installation use static 1433 and new installation dynamic port - and both will work without a port definition. because the default config has the 'port' entry, you might think you need to define it and a quick search will give you the anwser that 1433 is the default port for ms sql server.

maybe a notice in the database configuration documentation would be enough to help users to configure sqlsrv driver for new installations.

for now we will apply a migration ( on our end ) that remove all sqlsrv port entries with the value of 1433 to have the backward compatibility with old installations

@michalsn
Copy link
Member

michalsn commented Jun 28, 2023

@puschie286 Ok, now I understand what you mean. Thanks.

I'm not a fan of the proposed change. I don't want us to end up with a situation where someone defines a port as 1433 and their database is actually running on a different port.

A much more appropriate approach would be to add a note in the user guide - just like you mentioned.

@kenjis
Copy link
Member

kenjis commented Jun 28, 2023

The default instance of SQL Server listens for incoming connections on port 1433. ... By default, named instances (including SQL Server Express) are configured to listen on dynamic ports. To configure a static port, leave the TCP Dynamic Ports box blank and provide an available port number in the TCP Port box.
https://learn.microsoft.com/en-us/sql/tools/configuration-manager/tcp-ip-properties-ip-addresses-tab?view=sql-server-ver16#static-vs-dynamic-ports

I'm lost.
What is a named instance? How does it differ from the default instance?

I'm not sure, but are you saying that latest SQL server on Windows is installed to use dynamic port by default?

~ remove old port changes
+ add port config information to the documentation
@puschie286
Copy link
Contributor Author

@kenjis yes, dynamic port is the default setting nowadays.

A named instance is an installation with an different instance name than the default instance name - overall its just an alias to identify the sql server instance ( if you have multiple on the same host ). if you dont provide the instance name, the driver use the default instance name - so its not possible to have an "unnamed instance" ( this term is sometimes used but it just refer to default instance name ). You could say that the instance name is microsoft way of omit the port

i removed my change and added these information in the database configuration documentation

@kenjis kenjis added documentation Pull requests for documentation only and removed tests needed Pull requests that need tests labels Jun 29, 2023
@@ -174,7 +174,7 @@ Explanation of Values:
**compress** Whether or not to use client compression (``MySQLi`` only).
**strictOn** true/false (boolean) - Whether to force "Strict Mode" connections, good for ensuring strict SQL
while developing an application (``MySQLi`` only).
**port** The database port number.
**port** The database port number - Empty for default port (or dynamic port with ``SQLSRV``)
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do you mean an empty string?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

yes - empty string is the only value that works for all driver
( sqlsrv and postgre doesnt use empty function for validation )

Copy link
Member

@kenjis kenjis left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you!

@kenjis kenjis merged commit 120b08d into codeigniter4:develop Jun 29, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
documentation Pull requests for documentation only
Projects
None yet
Development

Successfully merging this pull request may close these issues.

BUG: I'm in the version 4.1.9 That works properly, but when I update to 4.2.1 the SQL Server 2017
4 participants