In MySQL Shell, connections to MySQL Server instances are handled by a session object. The following types of session object are available:
- Session: Use this session object type for new application development to communicate with MySQL Server instances where X Protocol is available. X Protocol offers the best integration with MySQL Server. For X Protocol to be available, X Plugin must be installed and enabled on the MySQL Server instance, which it is by default from MySQL 8.0. X Plugin listens to the port specified by- mysqlx_port, which defaults to 33060, so specify this port with connections using a- Session.
- ClassicSession: Use this session object type to interact with MySQL Server instances that do not have X Protocol available. This object is intended for running SQL against servers using classic MySQL protocol. The development API available for this kind of session is very limited. For example, there are none of the X DevAPI CRUD operations, no collection handling, and binding is not supported. For development, prefer- Sessionobjects whenever possible.
        ClassicSession is specific to MySQL Shell
        and cannot be used with other implementations of X DevAPI, such
        as MySQL Connectors.
      
      When you make the first connection to a MySQL Server instance,
      which can be done either while starting MySQL Shell or
      afterwards, a MySQL Shell global object named
      session is created to represent this
      connection. This particular session object is global because once
      created, it can be used in all of the MySQL Shell execution
      modes: SQL mode, JavaScript mode, and Python mode. The connection
      it represents is therefore referred to as the global session. The
      variable session holds a reference to this
      session object, and can be used in MySQL Shell in JavaScript mode
      and Python mode to work with the connection.
    
      The session global object can be either the
      Session type of session object or the
      ClassicSession type of session object,
      according to the protocol you select when making the connection to
      a MySQL Server instance. You can choose the protocol, and
      therefore the session object type, using a command option, or
      specify it as part of the connection data that you provide. To see
      information about the current global session, issue:
    
mysql-js []> session
<ClassicSession:user@example.com:3330>When the global session is connected, this shows the session object type and the address of the MySQL Server instance to which the global session is connected.
      If you choose a protocol explicitly or indicate it implicitly when
      making a connection, MySQL Shell tries to create the connection
      using that protocol, and returns an error if this fails. If your
      connection parameters do not indicate the protocol, MySQL Shell
      first tries to make the connection using classic MySQL protocol
      (returning the Session type of session object),
      and if this fails, tries to make the connection using X Protocol.
    
      To verify the results of your connection attempt, use
      MySQL Shell's \status command or the
      shell.status() method. These display the
      connection protocol and other information about the connection
      represented by the session global object, or
      return “Not Connected” if the
      session global object is not connected to a
      MySQL server. For example:
    
mysql-js []> shell.status()
MySQL Shell version 8.1.0-commercial
Connection Id:                9
Current schema:
Current user:                 root@localhost
SSL:                          Cipher in use: TLS_AES_256_GCM_SHA384 TLSv1.3
Using delimiter:              ;
Server version:               8.1.0-commercial MySQL Enterprise Server - Commercial
Protocol version:             Classic 10
Client library:               8.1.0
Connection:                   localhost via TCP/IP
TCP port:                     3306
Server characterset:          utf8mb4
Schema characterset:          utf8mb4
Client characterset:          utf8mb4
Conn. characterset:           utf8mb4
Result characterset:          utf8mb4
Compression:                  Disabled
Uptime:                       9 hours 42 min 5.0000 sec
Threads: 2  Questions: 61  Slow queries: 0  Opens: 176  Flush tables: 3  Open tables: 95  Queries per second avg: 0.001
      This section focuses on explaining the session objects that
      represent connections to MySQL Server instances, and the
      session global object. For full instructions
      and examples for each of the ways mentioned in this section to
      connect to MySQL Server instances, and the other options that are
      available for the connections, see
      Section 4.3, “MySQL Shell Connections”.